@import "https://fonts.bunny.net/css?family=albert-sans:200,300i,500,500i,700,700i|andada-pro:400,400i,500,500i,700,700i|cutive-mono:400|scada:400,700";

/* packages/ui/src/styles/reset.css */
@layer reset {
  *, *:before, *:after {
    box-sizing: border-box;
  }

  * {
    margin: 0;
    padding: 0;
  }

  html, body {
    overscroll-behavior: none;
  }

  html {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
  }

  body {
    min-block-size: 100vh;
    line-height: var(--leading-normal);
    font-family: var(--font-body);
    color: var(--ink);
    background: var(--paper);
    min-block-size: 100dvh;
  }

  img, picture, video, canvas, svg {
    display: block;
    max-inline-size: 100%;
  }

  input, button, textarea, select {
    font: inherit;
  }

  p, h1, h2, h3, h4, h5, h6 {
    overflow-wrap: break-word;
  }

  h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
  }

  fieldset {
    border: none;
    min-inline-size: 0;
  }

  button {
    cursor: pointer;
    color: inherit;
    background: none;
    border: none;
  }

  ul[role="list"], ol[role="list"] {
    list-style: none;
  }

  :focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
  }

  ::selection {
    background: var(--selection-bg);
    color: var(--selection-fg);
  }
}

/* packages/ui/src/styles/custom-media.css */
@custom-media --bp-sm (min-width: 40rem);

@custom-media --bp-md (min-width: 48rem);

@custom-media --bp-lg (min-width: 64rem);

@custom-media --bp-xl (min-width: 80rem);

/* packages/ui/src/styles/tokens.css */
@layer tokens {
  :root, [data-theme="light"], .light {
    --buncss-light: initial;
    --buncss-dark: ;
    color-scheme: light;
    --paper: oklch(.985 0 0);
    --ink: oklch(.22 .03 250);
    --accent: oklch(.5 .01 70);
    --accent-subtle: color-mix(in oklab, var(--accent) 10%, transparent);
    --on-accent: oklch(.98 0 0);
    --positive: oklch(.7 .16 145);
    --warning: oklch(.78 .15 85);
    --danger: oklch(.62 .2 25);
    --info: oklch(.55 .15 250);
    --surface: color-mix(in oklab, var(--paper) 94%, var(--ink));
    --surface-alt: color-mix(in oklab, var(--paper) 88%, var(--ink));
    --line: color-mix(in oklab, var(--paper) 78%, var(--ink));
    --muted: color-mix(in oklab, var(--ink) 55%, var(--paper));
    --selection-bg: oklch(from var(--accent) l c h / .3);
    --selection-fg: var(--ink);
    --space-3xs: .146rem;
    --space-2xs: .236rem;
    --space-xs: .382rem;
    --space-sm: .618rem;
    --space-md: 1rem;
    --space-lg: 1.618rem;
    --space-xl: 2.618rem;
    --space-2xl: 4.236rem;
    --safe-area-top: env(safe-area-inset-top, 0px);
    --safe-area-bottom: env(safe-area-inset-bottom, 0px);
    --safe-area-left: env(safe-area-inset-left, 0px);
    --safe-area-right: env(safe-area-inset-right, 0px);
    --font-body: "Albert Sans", sans-serif;
    --font-heading: "Scada", sans-serif;
    --font-mono: "Cutive Mono", monospace;
    --font-content: "Andada Pro", serif;
    --text-xs: .75rem;
    --text-sm: .875rem;
    --text-base: 1rem;
    --text-lg: 1.272rem;
    --text-xl: 1.618rem;
    --text-2xl: 2.058rem;
    --text-3xl: 2.618rem;
    --text-4xl: 3.33rem;
    --weight-normal: 400;
    --weight-medium: 500;
    --weight-semibold: 600;
    --weight-bold: 700;
    --leading-snug: 1.25;
    --leading-normal: 1.5;
    --radius-sm: .309rem;
    --radius-md: .5rem;
    --radius-lg: .809rem;
    --radius-xl: 1.309rem;
    --radius-full: 9999px;
    --control-2xs: 1.236rem;
    --control-xs: 1.618rem;
    --control-sm: 2.058rem;
    --control-md: 2.618rem;
    --control-lg: 3.33rem;
    --control-xl: 4.236rem;
    --shadow-sm: 0 1px 2px oklch(0 0 0 / .05);
    --shadow-md: 0 4px 8px oklch(0 0 0 / .08);
    --shadow-lg: 0 12px 24px oklch(0 0 0 / .12);
    --shadow-card: inset 0 0 2px -.75px oklch(0 0 0 / 8%), inset 0 0 1px -.25px oklch(0 0 0 / 16%);
    --scrim: oklch(0 0 0 / .55);
    --scrim-strong: oklch(0 0 0 / .7);
    --z-base: 0;
    --z-raised: 10;
    --z-sticky: 20;
    --z-overlay: 100;
    --z-popover: 200;
    --z-toast: 300;
    --z-modal: 1000;
    --z-max: 9999;
    --duration: .15s;
    --ease: cubic-bezier(.4, 0, .2, 1);
    --text-ui: var(--text-sm);
    --text-caption: var(--text-xs);
    --accent-hover: color-mix(in oklab, var(--accent) 85%, var(--ink));
    --focus-ring: color-mix(in oklab, var(--accent) 15%, transparent);
    --focus-ring-danger: color-mix(in oklab, var(--danger) 15%, transparent);
    --ink-muted: color-mix(in oklab, var(--ink) 55%, transparent);
    --tint-warning: color-mix(in oklab, var(--warning) 12%, transparent);
  }

  [data-theme="dark"], .dark {
    --buncss-light: ;
    --buncss-dark: initial;
    color-scheme: dark;
    --paper: oklch(.17 0 0);
    --ink: oklch(.95 .01 250);
    --accent: oklch(.7 .015 70);
    --accent-subtle: color-mix(in oklab, var(--accent) 10%, transparent);
    --on-accent: oklch(.12 0 0);
    --positive: oklch(.74 .14 145);
    --warning: oklch(.82 .14 85);
    --danger: oklch(.7 .18 25);
    --info: oklch(.7 .12 250);
    --surface: color-mix(in oklab, var(--paper) 97%, var(--ink));
    --surface-alt: color-mix(in oklab, var(--paper) 88%, var(--ink));
    --line: color-mix(in oklab, var(--paper) 78%, var(--ink));
    --muted: color-mix(in oklab, var(--ink) 55%, var(--paper));
    --shadow-sm: 0 1px 2px oklch(0 0 0 / .2);
    --shadow-md: 0 4px 8px oklch(0 0 0 / .25);
    --shadow-lg: 0 12px 24px oklch(0 0 0 / .3);
    --shadow-card: inset 0 0 2px -.75px oklch(1 0 0 / 10%), inset 0 0 1px -.25px oklch(1 0 0 / 25%);
    --selection-bg: oklch(from var(--accent) l c h / .3);
    --selection-fg: var(--ink);
  }

  @media (prefers-color-scheme: dark) {
    :root:not([data-theme]) {
      --buncss-light: ;
      --buncss-dark: initial;
      color-scheme: dark;
      --paper: oklch(.17 0 0);
      --ink: oklch(.95 .01 250);
      --accent: oklch(.7 .015 70);
      --accent-subtle: color-mix(in oklab, var(--accent) 10%, transparent);
      --on-accent: oklch(.12 0 0);
      --positive: oklch(.74 .14 145);
      --warning: oklch(.82 .14 85);
      --danger: oklch(.7 .18 25);
      --info: oklch(.7 .12 250);
      --surface: color-mix(in oklab, var(--paper) 97%, var(--ink));
      --surface-alt: color-mix(in oklab, var(--paper) 88%, var(--ink));
      --line: color-mix(in oklab, var(--paper) 78%, var(--ink));
      --muted: color-mix(in oklab, var(--ink) 55%, var(--paper));
      --shadow-sm: 0 1px 2px oklch(0 0 0 / .2);
      --shadow-md: 0 4px 8px oklch(0 0 0 / .25);
      --shadow-lg: 0 12px 24px oklch(0 0 0 / .3);
      --shadow-card: inset 0 0 2px -.75px oklch(1 0 0 / 10%), inset 0 0 1px -.25px oklch(1 0 0 / 25%);
      --selection-bg: oklch(from var(--accent) l c h / .3);
      --selection-fg: var(--ink);
    }
  }
}

/* packages/ui/src/styles/utility.css */
@layer utilities {
  [data-no-animation], [data-no-animation] * {
    animation: none !important;
    transition: none !important;
  }

  .stack {
    display: flex;
    gap: var(--stack-gap, var(--space-md));
    align-items: var(--stack-align, stretch);
    flex-direction: column;
  }

  .stack-3xs {
    --stack-gap: var(--space-3xs);
  }

  .stack-2xs {
    --stack-gap: var(--space-2xs);
  }

  .stack-xs {
    --stack-gap: var(--space-xs);
  }

  .stack-sm {
    --stack-gap: var(--space-sm);
  }

  .stack-lg {
    --stack-gap: var(--space-lg);
  }

  .stack-xl {
    --stack-gap: var(--space-xl);
  }

  .stack-2xl {
    --stack-gap: var(--space-2xl);
  }

  .row {
    display: flex;
    gap: var(--row-gap, var(--space-md));
    align-items: var(--row-align, center);
    justify-content: var(--row-justify, flex-start);
  }

  .row-wrap {
    flex-wrap: wrap;
  }

  .row-3xs {
    --row-gap: var(--space-3xs);
  }

  .row-2xs {
    --row-gap: var(--space-2xs);
  }

  .row-xs {
    --row-gap: var(--space-xs);
  }

  .row-sm {
    --row-gap: var(--space-sm);
  }

  .row-lg {
    --row-gap: var(--space-lg);
  }

  .row-xl {
    --row-gap: var(--space-xl);
  }

  .row-2xl {
    --row-gap: var(--space-2xl);
  }

  .auto-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(var(--grid-min, 16rem), 100%), 1fr));
    gap: var(--grid-gap, var(--space-md));
  }

  .auto-grid-fit {
    grid-template-columns: repeat(auto-fit, minmax(min(var(--grid-min, 16rem), 100%), 1fr));
  }

  .grid-explicit {
    display: grid;
    grid-template-columns: var(--grid-columns);
    gap: var(--grid-gap, var(--space-md));
  }

  .sr-only {
    position: absolute;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
    block-size: 1px;
    inline-size: 1px;
    margin: -1px;
    padding: 0;
  }

  .hidden {
    display: none;
  }
}

/* packages/ui/src/styles/blocks/surface.css */
@layer utilities {
  .surface {
    background: var(--surface-bg, var(--surface));
    border-radius: var(--surface-radius, var(--radius-lg));
    box-shadow: var(--surface-shadow, var(--shadow-card));
  }

  .surface[data-surface="elevated"] {
    --surface-shadow: var(--shadow-lg);
  }

  .surface[data-surface="outline"] {
    --surface-shadow: none;
  }

  .surface[data-surface="ghost"] {
    --surface-bg: transparent;
    --surface-shadow: none;
  }
}

/* packages/ui/src/styles/blocks/button.css */
@layer components {
  @keyframes button-spin {
    to {
      transform: rotate(360deg);
    }
  }

  :where(.button) {
    display: inline-flex;
    box-sizing: border-box;
    background: var(--button-bg, var(--accent));
    color: var(--button-fg, var(--paper));
    border: 1px solid var(--button-border, transparent);
    font-size: var(--button-font-size, var(--text-ui));
    font-weight: var(--weight-medium);
    white-space: nowrap;
    text-decoration: none;
    cursor: pointer;
    user-select: none;
    transition: all var(--duration) var(--ease);
    border-radius: .382em;
    justify-content: center;
    align-items:  center;
    gap: .618em;
    block-size: 2.618em;
    padding-block-start: 0;
    padding-block-end: 0;
    padding-inline-start: .809em;
    padding-inline-end: .809em;
    line-height: 1;
  }

  :where(.button) svg {
    flex-shrink: 0;
    block-size: 1.272em;
    inline-size: 1.272em;
  }

  :where(.button):hover:not(:disabled) {
    background: var(--button-bg-hover, var(--accent-hover));
    box-shadow: var(--shadow-sm);
  }

  :where(.button):disabled {
    opacity: .5;
    cursor: not-allowed;
  }

  :where(.button):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  .button[data-variant="outline"] {
    --button-bg: transparent;
    --button-fg: var(--ink);
    --button-border: var(--line);
    color: var(--ink);
  }

  .button[data-variant="outline"]:hover:not(:disabled) {
    background: color-mix(in oklab, var(--accent) 12%, var(--paper));
    border-color: color-mix(in oklab, var(--accent) 40%, var(--line));
    box-shadow: none;
  }

  .button[data-variant="outline"]:focus-visible {
    outline-color: var(--line);
  }

  .button[data-variant="ghost"] {
    --button-bg: transparent;
    --button-fg: var(--ink);
    --button-border: transparent;
    --button-bg-hover: var(--surface-alt);
  }

  .button[data-variant="frosted"] {
    border-radius: calc(var(--radius-lg) * 1.25);
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    background: color-mix(in oklab, var(--accent) 60%, transparent);
    color: var(--paper);
    backdrop-filter: blur(16px) saturate(160%);
    -webkit-backdrop-filter: blur(16px) saturate(160%);
    box-shadow: inset 0 1px 0 #ffffff4d, var(--shadow-md);
    border-color: #0000;
    min-block-size: 3.25rem;
    inline-size: 100%;
  }

  @supports (color: color(display-p3 0 0 0)) {
    .button[data-variant="frosted"] {
      box-shadow: inset 0 1px 0 color(display-p3 1 1 1 / .3), var(--shadow-md);
    }
  }

  @supports (color: lab(0% 0 0)) {
    .button[data-variant="frosted"] {
      box-shadow: inset 0 1px 0 lab(100% -.0000298023 .0000119209 / .3), var(--shadow-md);
    }
  }

  .button[data-variant="frosted"]:hover:not(:disabled) {
    background: color-mix(in oklab, var(--accent) 75%, transparent);
    box-shadow: inset 0 1px 0 #ffffff4d, var(--shadow-md);
  }

  @supports (color: color(display-p3 0 0 0)) {
    .button[data-variant="frosted"]:hover:not(:disabled) {
      box-shadow: inset 0 1px 0 color(display-p3 1 1 1 / .3), var(--shadow-md);
    }
  }

  @supports (color: lab(0% 0 0)) {
    .button[data-variant="frosted"]:hover:not(:disabled) {
      box-shadow: inset 0 1px 0 lab(100% -.0000298023 .0000119209 / .3), var(--shadow-md);
    }
  }

  [data-theme="light"] .button[data-variant="frosted"] {
    background: var(--accent);
  }

  [data-theme="light"] .button[data-variant="frosted"]:hover:not(:disabled) {
    background: var(--accent-hover);
  }

  @media (prefers-color-scheme: light) {
    :root:not([data-theme]) .button[data-variant="frosted"] {
      background: var(--accent);
    }

    :root:not([data-theme]) .button[data-variant="frosted"]:hover:not(:disabled) {
      background: var(--accent-hover);
    }
  }

  .button[data-variant="subtle"] {
    --button-bg: transparent;
    --button-fg: color-mix(in oklab, var(--ink) 60%, transparent);
    --button-border: transparent;
    color: var(--button-fg);
  }

  .button[data-variant="subtle"]:hover:not(:disabled) {
    --button-fg: var(--ink);
    color: var(--button-fg);
    box-shadow: none;
    background: none;
  }

  .button[data-size="sm"] {
    font-size: var(--text-caption);
  }

  .button[data-size="lg"] {
    font-size: var(--text-base);
  }

  .button[data-icon] {
    aspect-ratio: 1;
    inline-size: 2.618em;
    padding-inline-start: 0;
    padding-inline-end: 0;
  }

  .button[data-tone="danger"] {
    --button-bg: var(--danger);
    --button-bg-hover: color-mix(in oklab, var(--danger) 90%, black 10%);
  }

  .button[data-variant="outline"][data-tone="danger"] {
    --button-bg: transparent;
    --button-fg: var(--danger);
    --button-border: var(--danger);
    color: var(--danger);
  }

  .button[data-variant="outline"][data-tone="danger"]:hover:not(:disabled) {
    background: color-mix(in oklab, var(--danger) 12%, var(--paper));
    border-color: color-mix(in oklab, var(--danger) 70%, var(--line));
  }

  .button[data-variant="ghost"][data-tone="danger"], .button[data-variant="subtle"][data-tone="danger"] {
    --button-bg: transparent;
    --button-fg: var(--danger);
    --button-bg-hover: color-mix(in oklab, var(--danger) 12%, transparent);
    color: var(--danger);
  }

  .button[data-loading] {
    position: relative;
    color: #0000;
    pointer-events: none;
  }

  .button[data-loading]:after {
    content: "";
    color: var(--button-fg, var(--paper));
    position: absolute;
    animation: button-spin .6s linear infinite;
    border: 2px solid;
    border-right-color: #0000;
    border-radius: 50%;
    block-size: 1.272em;
    inline-size: 1.272em;
    margin: auto;
    inset: 0;
  }
}

/* packages/ui/src/styles/blocks/toggle-button.css */
@layer components {
  :where(.ToggleButton) {
    color: var(--muted);
    transition: color var(--duration) var(--ease), transform .15s var(--ease);
  }

  :where(.ToggleButton):hover:not(:disabled) {
    color: var(--ink);
  }

  .ToggleButton[data-toggled] {
    color: var(--toggle-active-color, var(--accent));
  }

  .ToggleButton[data-toggled]:hover:not(:disabled) {
    color: var(--toggle-active-color, var(--accent));
    opacity: .8;
  }

  .ToggleButton[data-toggled]:not([data-updating]) {
    animation: toggle-pop .3s var(--ease);
  }

  @keyframes toggle-pop {
    0% {
      transform: scale(1);
    }

    50% {
      transform: scale(1.25);
    }

    100% {
      transform: scale(1);
    }
  }

  .ToggleButton[data-updating] {
    animation: toggle-pulse 1s ease infinite;
  }

  @keyframes toggle-pulse {
    0%, 100% {
      opacity: 1;
    }

    50% {
      opacity: .4;
    }
  }

  .ToggleButton:active:not(:disabled) {
    transform: scale(.9);
  }

  .ToggleButton:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }
}

/* packages/ui/src/styles/blocks/segmented-control.css */
@layer components {
  :where(.segmented-control) {
    position: relative;
    display: inline-flex;
    font-size: var(--segmented-font-size, var(--text-ui));
    block-size: var(--segmented-block-size, 2.618em);
    border-radius: var(--segmented-radius, .382em);
    background: var(--segmented-bg, var(--surface-alt));
    color: var(--segmented-fg, var(--muted));
    padding: var(--segmented-padding, .191em);
    justify-content: center;
    align-items:  center;
    inline-size: -moz-fit-content;
    inline-size: fit-content;
  }

  :where(.segmented-control) .segmented-control-indicator {
    position: absolute;
    inset-block: var(--segmented-padding, .191em);
    inline-size: var(--indicator-width);
    transform: translateX(var(--indicator-left));
    border-radius: var(--segmented-indicator-radius, .309em);
    background: var(--segmented-indicator-bg, var(--paper));
    box-shadow: var(--shadow-sm);
    pointer-events: none;
  }

  :where(.segmented-control) .segmented-control-indicator:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 0;
  }

  :where(.segmented-control) .segmented-control-indicator:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 0;
  }

  :where(.segmented-control) .segmented-control-indicator:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 0;
  }

  :where(.segmented-control) .segmented-control-indicator:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 0;
  }

  :where(.segmented-control) .segmented-control-indicator:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 0;
  }

  :where(.segmented-control) .segmented-control-indicator:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 0;
  }

  :where(.segmented-control)[data-animated] .segmented-control-indicator {
    transition: transform var(--duration) var(--ease), inline-size var(--duration) var(--ease);
  }

  :where(.segmented-control) :where(.segmented-control-button) {
    position: relative;
    z-index: 1;
    display: inline-flex;
    justify-content: center;
    align-items:  center;
    gap: var(--segmented-button-gap, .382em);
    border-radius: var(--segmented-button-radius, var(--segmented-indicator-radius, .309em));
    padding-inline: var(--segmented-button-px, .809em);
    padding-block: var(--segmented-button-py, .382em);
    font-size: inherit;
    font-weight: var(--weight-medium);
    white-space: nowrap;
    cursor: pointer;
    transition: color var(--duration) var(--ease);
    color: inherit;
    background: none;
    border: none;
    block-size: calc(100% - 1px);
  }

  :where(.segmented-control) :where(.segmented-control-button)[data-active] {
    color: var(--ink);
  }

  :where(.segmented-control) :where(.segmented-control-button):hover:not([data-active]):not(:disabled) {
    color: var(--ink);
  }

  :where(.segmented-control) :where(.segmented-control-button):disabled {
    opacity: .5;
    cursor: not-allowed;
  }

  :where(.segmented-control) :where(.segmented-control-button):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 1px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.segmented-control)[data-size="sm"] {
    font-size: var(--segmented-font-size-sm, var(--text-caption));
    block-size: var(--segmented-block-size-sm, var(--segmented-block-size, 2.618em));
  }
}

/* packages/ui/src/styles/blocks/alphabetical-index.css */
@layer components {
  :where(.alphabetical-index) {
    --alphabetical-index-item-size: 1.75rem;
    --alphabetical-index-active-bg: color-mix(in oklab, var(--ink) 8%, transparent);
    --alphabetical-index-hover-bg: color-mix(in oklab, var(--ink) 6%, transparent);
    --alphabetical-index-active-hover-bg: color-mix(in oklab, var(--ink) 14%, transparent);
    display: grid;
    gap: var(--space-sm);
  }

  :where(.alphabetical-index-search) {
    position: relative;
  }

  :where(.alphabetical-index-search .input-wrapper) {
    position: relative;
    isolation: isolate;
  }

  :where(.alphabetical-index-search .input-wrapper):before {
    content: "";
    position: absolute;
    border-radius: var(--input-radius, var(--radius-lg));
    background: var(--alphabetical-index-active-bg);
    pointer-events: none;
    z-index: -1;
    inset: 0;
  }

  :where(.alphabetical-index-search .input) {
    --input-bg: transparent;
    --input-border: transparent;
    --input-border-hover: transparent;
    --input-radius: var(--radius-lg);
  }

  :where(.alphabetical-index-search .input):focus {
    box-shadow: inset 0 0 0 2px var(--accent);
    border-color: #0000;
  }

  :where(.alphabetical-index-scroller) {
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    -ms-overflow-style: none;
    min-block-size: calc(var(--alphabetical-index-item-size)  + (var(--space-xs) * 2));
    overscroll-behavior-x: contain;
    scroll-padding-inline: var(--space-xs);
    padding-inline: var(--space-xs);
    padding-block: var(--space-xs);
  }

  :where(.alphabetical-index-scroller)::-webkit-scrollbar {
    display: none;
  }

  :where(.alphabetical-index-nav) {
    display: flex;
    gap: var(--space-2xs);
    min-block-size: var(--alphabetical-index-item-size);
    flex-wrap: nowrap;
    inline-size: max-content;
  }

  :where(.alphabetical-index-item) {
    display: inline-flex;
    min-inline-size: var(--alphabetical-index-item-size);
    block-size: var(--alphabetical-index-item-size);
    padding-inline: var(--space-sm);
    border-radius: var(--radius-full);
    color: var(--muted);
    font-size: var(--text-caption);
    font-weight: var(--weight-medium);
    text-decoration: none;
    white-space: nowrap;
    transition: background var(--duration) var(--ease), color var(--duration) var(--ease);
    background: none;
    border: none;
    flex: none;
    justify-content: center;
    align-items:  center;
    line-height: 1;
  }

  :where(button.alphabetical-index-item) {
    cursor: pointer;
  }

  :where(a.alphabetical-index-item) {
    cursor: pointer;
  }

  :where(.alphabetical-index-item)[data-active] {
    color: var(--ink);
    background: var(--alphabetical-index-active-bg);
  }

  :where(.alphabetical-index-item):hover:not([data-disabled]) {
    color: var(--ink);
    background: var(--alphabetical-index-hover-bg);
  }

  :where(.alphabetical-index-item):focus-visible {
    color: var(--ink);
    background: var(--alphabetical-index-hover-bg);
  }

  :where(.alphabetical-index-item)[data-active]:hover {
    background: var(--alphabetical-index-active-hover-bg);
  }

  :where(.alphabetical-index-item)[data-active]:focus-visible {
    background: var(--alphabetical-index-active-hover-bg);
  }

  :where(.alphabetical-index-item:focus-visible) {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 3px var(--focus-ring);
  }

  :where(.alphabetical-index-item)[data-disabled] {
    opacity: .45;
    pointer-events: none;
  }
}

/* packages/ui/src/styles/blocks/card.css */
@layer components {
  :where(.card) {
    position: relative;
    font-family: var(--font-body);
    background: var(--surface-bg, var(--surface));
    border-radius: var(--surface-radius, var(--radius-lg));
    box-shadow: var(--surface-shadow, var(--shadow-card));
    padding: var(--card-padding, var(--space-lg));
    transition: box-shadow var(--duration) var(--ease);
  }

  .card[data-variant="outline"] {
    --surface-shadow: 0 0 0 1px var(--line);
  }

  .card[data-variant="ghost"] {
    --surface-bg: transparent;
    --surface-shadow: none;
  }

  .card[data-interactive] {
    cursor: pointer;
    transition: box-shadow var(--duration) var(--ease), transform var(--duration) var(--ease);
  }

  .card[data-interactive]:hover {
    box-shadow: var(--shadow-card), inset 0 0 1px color-mix(in oklab, var(--accent) 25%, transparent), inset 0 0 5rem color-mix(in oklab, var(--accent) 5%, transparent);
    transition-duration: calc(var(--duration) * 1.5);
    transform: scale(1.02);
  }

  .card[data-interactive]:active {
    transform: scale(.98);
  }

  .card-title {
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: var(--weight-normal);
    line-height: var(--leading-snug);
  }

  .card-footer {
    padding-block-start: var(--space-md);
  }
}

/* packages/ui/src/styles/blocks/cover-card.css */
@layer components {
  :where(.cover-card) {
    position: relative;
    display: flex;
    overflow: hidden;
    min-block-size: var(--cover-card-min-h, 14rem);
    flex-direction: column;
  }

  :where(.cover-card-media) {
    position: absolute;
    z-index: 0;
    inset: 0;
  }

  :where(.cover-card-media) .media-image {
    block-size: 100%;
    inline-size: 100%;
  }

  .cover-card-media .media-image-img, .cover-card-media .media-image-placeholder {
    object-fit: cover;
    transform: var(--cover-card-scale, none);
    transition: opacity .3s ease-out, transform var(--duration) var(--ease);
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.cover-card-media):after {
    content: "";
    position: absolute;
    background: linear-gradient(to top, color-mix(in oklab, var(--paper) 90%, transparent) 0%, color-mix(in oklab, var(--paper) 60%, transparent) 40%, transparent 100%);
    animation: media-image-placeholder-enter .3s ease-out;
    inset: 0;
  }

  :where(.cover-card-content) {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    flex: 1;
    justify-content: flex-end;
  }
}

/* packages/ui/src/styles/blocks/input.css */
@layer components {
  :where(.input) {
    display: block;
    min-block-size: var(--input-size, var(--control-md));
    padding-inline: var(--input-px, var(--space-sm));
    padding-block: var(--input-py, var(--space-xs));
    background: var(--input-bg, var(--paper));
    color: var(--input-fg, var(--ink));
    border: 1px solid var(--input-border, var(--line));
    border-radius: var(--input-radius, var(--radius-md));
    font-size: var(--input-font-size, var(--text-ui));
    line-height: var(--leading-normal);
    transition: border-color var(--duration) var(--ease);
    inline-size: 100%;
  }

  :where(.input)::placeholder {
    color: var(--muted);
  }

  :where(.input):hover:not(:disabled) {
    border-color: var(--input-border-hover, var(--accent));
  }

  :where(.input):focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--focus-ring);
  }

  :where(.input):disabled {
    opacity: .5;
    cursor: not-allowed;
    background: var(--surface);
  }

  :where(.input)[aria-invalid="true"] {
    border-color: var(--danger);
  }

  :where(.input)[aria-invalid="true"]:focus {
    box-shadow: 0 0 0 3px var(--focus-ring-danger);
  }

  textarea.input {
    resize: vertical;
    padding-block: var(--space-sm);
    min-block-size: 8rem;
  }

  .input-wrapper {
    position: relative;
    display: flex;
    align-items:  center;
    inline-size: 100%;
  }

  .input-wrapper > .input {
    inline-size: 100%;
  }

  .input-wrapper[data-leading] > .input {
    padding-inline-start: calc(var(--space-md) * 2.25);
  }

  .input-wrapper[data-trailing] > .input {
    padding-inline-end: calc(var(--space-md) * 2.25);
  }

  .input-icon {
    position: absolute;
    color: var(--muted);
    pointer-events: none;
    flex-shrink: 0;
  }

  .input-icon-leading:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: var(--space-sm);
  }

  .input-icon-leading:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: var(--space-sm);
  }

  .input-icon-leading:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: var(--space-sm);
  }

  .input-icon-leading:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: var(--space-sm);
  }

  .input-icon-leading:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: var(--space-sm);
  }

  .input-icon-leading:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: var(--space-sm);
  }

  .input-icon-trailing:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: var(--space-sm);
  }

  .input-icon-trailing:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: var(--space-sm);
  }

  .input-icon-trailing:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: var(--space-sm);
  }

  .input-icon-trailing:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: var(--space-sm);
  }

  .input-icon-trailing:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: var(--space-sm);
  }

  .input-icon-trailing:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: var(--space-sm);
  }
}

/* packages/ui/src/styles/blocks/select.css */
@layer components {
  :where(.select-wrapper) {
    position: relative;
    display: inline-flex;
    inline-size: 100%;
  }

  :where(.select) {
    display: block;
    min-block-size: var(--input-size, var(--control-md));
    padding-inline-start: var(--input-px, var(--space-sm));
    padding-inline-end: calc(var(--space-sm)  + var(--space-lg));
    padding-block: var(--input-py, var(--space-xs));
    appearance: none;
    background: var(--input-bg, var(--paper));
    color: var(--input-fg, var(--ink));
    border: 1px solid var(--input-border, var(--line));
    border-radius: var(--input-radius, var(--radius-md));
    font-size: var(--input-font-size, var(--text-ui));
    line-height: var(--leading-normal);
    cursor: pointer;
    transition: border-color var(--duration) var(--ease);
    inline-size: 100%;
  }

  :where(.select):hover:not(:disabled) {
    border-color: var(--input-border-hover, var(--accent));
  }

  :where(.select):focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--focus-ring);
  }

  :where(.select):disabled {
    opacity: .5;
    cursor: not-allowed;
    background: var(--surface);
  }

  :where(.select)[aria-invalid="true"] {
    border-color: var(--danger);
  }

  :where(.select)[aria-invalid="true"]:focus {
    box-shadow: 0 0 0 3px var(--focus-ring-danger);
  }

  :where(.select):invalid {
    color: var(--muted);
  }

  :where(.select)[data-placeholder] {
    color: var(--muted);
  }

  :where(.select-icon) {
    position: absolute;
    right: var(--space-sm);
    inline-size: var(--space-md);
    block-size: var(--space-md);
    color: var(--muted);
    pointer-events: none;
    margin-block-start: auto;
    margin-block-end: auto;
    top: 0;
    bottom: 0;
  }
}

/* packages/ui/src/styles/blocks/badge.css */
@layer components {
  :where(.badge) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-xs);
    padding-inline: var(--badge-px, var(--space-sm));
    padding-block: var(--badge-py, calc(var(--space-xs) / 2));
    background: var(--badge-bg, color-mix(in oklab, var(--ink) 12%, transparent));
    color: var(--badge-fg, var(--muted));
    border: 1px solid var(--badge-border, transparent);
    border-radius: var(--radius-full);
    font-size: var(--badge-fs, var(--text-caption));
    font-weight: var(--weight-medium);
    white-space: nowrap;
    justify-self: flex-start;
    line-height: 1;
  }

  :where(.badge) > svg {
    flex-shrink: 0;
    block-size: .875em;
    inline-size: .875em;
  }

  .badge[data-tone="positive"] {
    --badge-bg: color-mix(in oklab, var(--positive) 22%, transparent);
    --badge-fg: color-mix(in oklab, var(--positive) 85%, var(--ink) 15%);
  }

  .badge[data-tone="danger"] {
    --badge-bg: color-mix(in oklab, var(--danger) 22%, transparent);
    --badge-fg: color-mix(in oklab, var(--danger) 85%, var(--ink) 15%);
  }

  .badge[data-tone="warning"] {
    --badge-bg: color-mix(in oklab, var(--warning) 22%, transparent);
    --badge-fg: color-mix(in oklab, var(--warning) 80%, var(--ink) 20%);
  }
}

/* packages/ui/src/styles/blocks/kbd.css */
@layer components {
  :where(.kbd) {
    display: inline-flex;
    min-inline-size: var(--control-xs);
    block-size: var(--control-xs);
    padding-inline: var(--kbd-px, var(--space-xs));
    background: var(--kbd-bg, var(--surface));
    color: var(--kbd-fg, var(--muted));
    border: 1px solid var(--kbd-border, var(--line));
    border-radius: var(--kbd-radius, var(--radius-sm));
    box-shadow: var(--kbd-shadow, 0 1px 0 var(--line));
    font-family: inherit;
    font-size: var(--kbd-font-size, var(--text-caption));
    font-weight: var(--weight-medium);
    white-space: nowrap;
    justify-content: center;
    align-items:  center;
    line-height: 1;
  }

  .kbd[data-size="sm"] {
    min-inline-size: var(--control-2xs);
    block-size: var(--control-2xs);
    --kbd-px: .236rem;
    --kbd-font-size: .486rem;
  }
}

/* packages/ui/src/styles/blocks/form.css */
@layer components {
  .form {
    display: flex;
    gap: var(--form-gap, var(--space-sm));
    max-inline-size: var(--form-max-inline-size, none);
    flex-direction: column;
  }
}

/* packages/ui/src/styles/blocks/field.css */
@layer components {
  :where(.field) {
    --field-label-color: var(--ink);
    --field-description-color: var(--muted);
    display: flex;
    gap: var(--field-gap, var(--space-sm));
    flex-direction: column;
  }

  :where(.field-label) {
    display: inline-flex;
    align-items:  center;
    gap: var(--field-label-gap, var(--space-sm));
    font-size: var(--field-label-size, var(--text-ui));
    font-weight: var(--field-label-weight, var(--weight-medium));
    line-height: var(--leading-normal);
    color: var(--field-label-color);
    cursor: pointer;
  }

  :where(.field-label)[data-disabled] {
    cursor: not-allowed;
    opacity: .6;
  }

  :where(.field-control) {
    display: contents;
  }

  :where(.field-description) {
    font-size: var(--field-description-size, var(--text-ui));
    color: var(--field-description-color);
  }

  :where(.field-error) {
    color: var(--danger);
  }

  :where(.field):focus-within {
    --field-label-color: var(--field-focused-label-color, var(--ink));
  }

  :where(.field):has(:-webkit-any(input, textarea, select, [data-slot="date-picker-trigger"], [data-slot="picker-trigger"])[aria-invalid="true"]) {
    --field-label-color: var(--field-invalid-label-color, var(--danger));
    --input-border: var(--input-border-error, color-mix(in oklab, var(--danger) 65%, transparent));
    --input-border-hover: var(--input-border-error-hover, color-mix(in oklab, var(--danger) 80%, transparent));
    --checkbox-border: var(--checkbox-border-error, color-mix(in oklab, var(--danger) 65%, transparent));
  }

  :where(.field):has(:-moz-any(input, textarea, select, [data-slot="date-picker-trigger"], [data-slot="picker-trigger"])[aria-invalid="true"]) {
    --field-label-color: var(--field-invalid-label-color, var(--danger));
    --input-border: var(--input-border-error, color-mix(in oklab, var(--danger) 65%, transparent));
    --input-border-hover: var(--input-border-error-hover, color-mix(in oklab, var(--danger) 80%, transparent));
    --checkbox-border: var(--checkbox-border-error, color-mix(in oklab, var(--danger) 65%, transparent));
  }

  :where(.field):has(:is(input, textarea, select, [data-slot="date-picker-trigger"], [data-slot="picker-trigger"])[aria-invalid="true"]) {
    --field-label-color: var(--field-invalid-label-color, var(--danger));
    --input-border: var(--input-border-error, color-mix(in oklab, var(--danger) 65%, transparent));
    --input-border-hover: var(--input-border-error-hover, color-mix(in oklab, var(--danger) 80%, transparent));
    --checkbox-border: var(--checkbox-border-error, color-mix(in oklab, var(--danger) 65%, transparent));
  }
}

/* packages/ui/src/styles/blocks/fieldset.css */
@layer components {
  .fieldset {
    display: flex;
    gap: var(--fieldset-gap, var(--space-md));
    padding: var(--fieldset-padding, 0);
    border: none;
    flex-direction: column;
    min-inline-size: 0;
    margin: 0;
  }

  .fieldset[data-disabled] {
    opacity: .6;
    cursor: not-allowed;
  }

  .fieldset-legend {
    display: flex;
    align-items:  center;
    gap: var(--fieldset-legend-gap, var(--space-sm));
    font-size: var(--fieldset-legend-size, var(--text-ui));
    font-weight: var(--fieldset-legend-weight, 600);
    color: var(--fieldset-legend-color, var(--muted));
    text-transform: uppercase;
    letter-spacing: .08em;
    margin: 0;
  }
}

/* packages/ui/src/styles/blocks/field-group.css */
@layer components {
  :where(.field-group) {
    display: block;
    overflow: hidden;
    background: color-mix(in oklab, var(--surface) 50%, transparent);
    border: 1px solid color-mix(in oklab, var(--ink) 12%, transparent);
    border-radius: calc(var(--radius-lg) * 1.25);
    backdrop-filter: blur(24px) saturate(150%);
    -webkit-backdrop-filter: blur(24px) saturate(150%);
    box-shadow: inset 0 1px 0 color-mix(in oklab, var(--ink) 6%, transparent), var(--shadow-md);
    transition: border-color var(--duration) var(--ease), background var(--duration) var(--ease);
  }

  :where(.field-group):focus-within {
    border-color: color-mix(in oklab, var(--accent) 45%, transparent);
    background: color-mix(in oklab, var(--surface) 60%, transparent);
  }

  :where(.field-group-field) {
    position: relative;
  }

  :where(.field-group-field) + :where(.field-group-field):before {
    content: "";
    position: absolute;
    background: color-mix(in oklab, var(--ink) 10%, transparent);
    pointer-events: none;
    block-size: 1px;
    top: 0;
    left: 0;
    right: 0;
  }

  :where(.field-group) :where(.label) {
    position: absolute;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0;
    block-size: 1px;
    inline-size: 1px;
    margin: -1px;
    padding: 0;
  }

  :where(.field-group) :where(.input) {
    padding-inline: var(--space-md);
    padding-block: var(--space-sm);
    font-size: var(--text-base);
    background: none;
    border: 0;
    border-radius: 0;
    min-block-size: 3.25rem;
  }

  :where(.field-group) :where(.input):hover:not(:disabled) {
    border-color: #0000;
  }

  :where(.field-group) :where(.input):focus {
    outline: none;
    box-shadow: none;
    background: color-mix(in oklab, var(--accent) 8%, transparent);
  }

  :where(.field-group) :where(.input)::placeholder {
    color: color-mix(in oklab, var(--ink) 45%, transparent);
  }

  :where(.field-group) :where(.input):disabled {
    background: none;
  }

  :where(.field-group) :where(.input)[aria-invalid="true"] {
    background: color-mix(in oklab, var(--danger) 8%, transparent);
  }
}

/* packages/ui/src/styles/blocks/label.css */
@layer components {
  .label {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    line-height: var(--leading-normal);
    color: var(--ink);
    cursor: pointer;
  }

  .label[data-disabled] {
    opacity: .5;
    cursor: not-allowed;
  }
}

/* packages/ui/src/styles/blocks/separator.css */
@layer components {
  .separator {
    background: var(--line);
    border: 0;
  }

  .separator[data-orientation="horizontal"] {
    block-size: 1px;
    inline-size: 100%;
  }

  .separator[data-orientation="vertical"] {
    block-size: 100%;
    inline-size: 1px;
  }
}

/* packages/ui/src/styles/blocks/rule.css */
@layer components {
  :where(.rule) {
    background: var(--line);
    border: 0;
    block-size: 1px;
    inline-size: 100%;
  }

  :where(.rule[data-fade="end"]) {
    background: linear-gradient(to right, var(--line) 0%, var(--line) 70%, transparent 100%);
  }

  :where(.rule[data-fade="both"]) {
    background: linear-gradient(to right, transparent 0%, var(--line) 15%, var(--line) 85%, transparent 100%);
  }
}

/* packages/ui/src/styles/blocks/skeleton.css */
@keyframes skeleton-pulse {
  0%, 100% {
    opacity: 1;
  }

  50% {
    opacity: .5;
  }
}

@layer components {
  .skeleton {
    background: var(--surface-alt);
    border-radius: var(--radius-md);
  }

  @media (prefers-reduced-motion: no-preference) {
    .skeleton {
      animation: skeleton-pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;
    }
  }

  .skeleton[data-shimmer="false"] {
    animation: none;
  }
}

/* packages/ui/src/styles/blocks/spinner.css */
@layer components {
  @keyframes spinner-wave {
    0%, 100% {
      transform: translateY(0);
    }

    50% {
      transform: translateY(-10%);
    }
  }

  @keyframes spinner-spin {
    from {
      transform: rotate(0);
    }

    to {
      transform: rotate(360deg);
    }
  }

  @keyframes spinner-fade-in {
    to {
      opacity: 1;
    }
  }

  @keyframes spinner-chase {
    0%, 100% {
      opacity: .15;
    }

    11% {
      opacity: 1;
    }

    55% {
      opacity: .15;
    }
  }

  :where(.spinner) {
    display: inline-block;
    inline-size: var(--spinner-size, var(--space-md));
    block-size: var(--spinner-size, var(--space-md));
  }

  :where(.spinner-fade-in) {
    opacity: 0;
    animation: spinner-fade-in .3s ease .4s forwards;
  }

  :where(.spinner-dot) {
    fill: var(--accent);
    transition: fill var(--duration) var(--ease);
    animation: spinner-chase 1.8s ease-in-out infinite;
  }

  :where(.spinner-dots) {
    animation: spinner-spin 2.4s linear infinite;
    transform-origin: center;
    transform-box: view-box;
  }

  .spinner[data-size="sm"] {
    --spinner-size: var(--space-sm);
  }

  .spinner[data-size="lg"] {
    --spinner-size: var(--space-xl);
  }

  .spinner[data-size="lg"] .spinner-dots {
    animation: none;
  }

  .spinner[data-size="lg"] .spinner-dot {
    transform-box: view-box;
    animation: spinner-wave 1.4s ease-in-out infinite;
  }

  @media (prefers-reduced-motion: reduce) {
    :where(.spinner-dots) {
      animation: none;
    }

    :where(.spinner-dot) {
      animation: none;
      opacity: .6;
    }
  }
}

/* packages/ui/src/styles/blocks/thinking.css */
@layer components {
  :where(.thinking) {
    display: inline-flex;
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    align-items:  center;
    min-inline-size: 0;
    line-height: 1.2;
  }

  :where(.thinking-visible) {
    display: inline-flex;
    align-items:  center;
    min-inline-size: 0;
  }

  :where(.thinking-word) {
    display: inline-grid;
    grid-template-areas: "stack";
    perspective: 520px;
    perspective-origin: 50% 50%;
    align-items:  center;
    min-inline-size: 0;
    line-height: 1;
  }

  :where(.thinking-word-base) {
    grid-area: stack;
  }

  :where(.thinking-word-shimmer) {
    grid-area: stack;
  }

  :where(.thinking-word-base) {
    display: inline-flex;
    align-items:  center;
    min-inline-size: 0;
    line-height: 1;
  }

  :where(.thinking-char) {
    display: inline-block;
    transform-origin: 50% 60%;
    transform-style: preserve-3d;
    color: color-mix(in oklab, var(--accent) 72%, var(--ink) 28%);
    backface-visibility: hidden;
    padding-block-end: .08em;
  }

  :where(.thinking-word[data-state="in"] .thinking-char) {
    animation: thinking-char-in .32s cubic-bezier(.2, .85, .25, 1) both;
    animation-delay: calc(var(--i) * var(--thinking-enter-stagger, 26ms));
  }

  :where(.thinking-word[data-state="out"] .thinking-char) {
    animation: thinking-char-out .22s cubic-bezier(.55, 0, .7, .2) both;
    animation-delay: calc(var(--i) * var(--thinking-exit-stagger, 14ms));
  }

  :where(.thinking-word-shimmer) {
    pointer-events: none;
    display: inline-block;
    background: linear-gradient(100deg, transparent 0%, transparent 42%, color-mix(in oklab, white 78%, var(--accent)) 48%, color-mix(in oklab, white 100%, var(--accent)) 50%, color-mix(in oklab, white 78%, var(--accent)) 52%, transparent 58%, transparent 100%);
    -webkit-text-fill-color: transparent;
    color: #0000;
    opacity: 0;
    white-space: pre;
    background-position: 125%;
    background-repeat: no-repeat;
    background-size: 220% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    padding-block-end: .08em;
  }

  :where(.thinking-word[data-state="in"] .thinking-word-shimmer) {
    animation: thinking-shimmer-sweep .82s cubic-bezier(.4, 0, .2, 1) var(--thinking-shimmer-delay, .26s) 1 both;
  }

  @keyframes thinking-char-in {
    0% {
      opacity: 0;
      transform: translateY(-.35em)rotateX(75deg);
      filter: blur(6px);
    }

    60% {
      opacity: 1;
      filter: blur(0);
    }

    100% {
      opacity: 1;
      transform: translateY(0)rotateX(0);
      filter: blur(0);
    }
  }

  @keyframes thinking-char-out {
    0% {
      opacity: 1;
      transform: translateY(0)rotateX(0);
      filter: blur(0);
    }

    100% {
      opacity: 0;
      transform: translateY(.3em)rotateX(-60deg);
      filter: blur(4px);
    }
  }

  @keyframes thinking-shimmer-sweep {
    0% {
      opacity: 0;
      background-position: 125%;
    }

    12% {
      opacity: 1;
    }

    88% {
      opacity: 1;
    }

    100% {
      opacity: 0;
      background-position: -25%;
    }
  }

  @media (prefers-reduced-motion: reduce) {
    :where(.thinking-word[data-state="in"] .thinking-char) {
      animation: none;
      filter: none;
      opacity: 1;
      transform: none;
    }

    :where(.thinking-word[data-state="out"] .thinking-char) {
      animation: none;
      filter: none;
      opacity: 1;
      transform: none;
    }

    :where(.thinking-word[data-state="in"] .thinking-word-shimmer) {
      animation: none;
      filter: none;
      opacity: 1;
      transform: none;
    }

    :where(.thinking-word-shimmer) {
      opacity: 0;
    }
  }
}

/* packages/ui/src/styles/blocks/scroll-area.css */
@layer components {
  :where(.scroll-area) {
    position: relative;
    overflow: auto;
  }

  :where(.scroll-area)[data-direction="x"] {
    overflow-x: auto;
    overflow-y: hidden;
  }

  :where(.scroll-area)[data-direction="y"] {
    overflow-x: hidden;
    overflow-y: auto;
  }

  :where(.scroll-area)[data-fade="bottom"] {
    mask-image: linear-gradient(#000 calc(100% - 2.5rem), #0000 100%);
  }

  :where(.scroll-area)[data-fade="top"] {
    mask-image: linear-gradient(to top, #000 calc(100% - 2.5rem), #0000 100%);
  }

  :where(.scroll-area)[data-fade="both"] {
    mask-image: linear-gradient(#0000 0%, #000 2.5rem calc(100% - 2.5rem), #0000 100%);
  }

  :where(.scroll-area)[data-hide-scrollbar] {
    scrollbar-width: none;
    -ms-overflow-style: none;
  }

  :where(.scroll-area)[data-hide-scrollbar]::-webkit-scrollbar {
    display: none;
  }

  :where(.scroll-area-viewport) {
    border-radius: inherit;
    overflow: auto;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.scroll-area-content) {
    min-inline-size: 100%;
  }

  :where(.scroll-area-scrollbar) {
    display: flex;
    user-select: none;
    touch-action: none;
    padding: var(--space-xs);
    transition: background var(--duration) var(--ease);
    background: none;
  }

  :where(.scroll-area-scrollbar)[data-state="hidden"] {
    display: none;
  }

  :where(.scroll-area-scrollbar)[data-orientation="vertical"] {
    inline-size: var(--space-sm);
  }

  :where(.scroll-area-scrollbar)[data-orientation="horizontal"] {
    block-size: var(--space-sm);
    flex-direction: column;
  }

  :where(.scroll-area-scrollbar):hover {
    background: color-mix(in oklab, var(--line) 55%, transparent);
  }

  :where(.scroll-area-thumb) {
    border-radius: var(--radius-full);
    background: color-mix(in oklab, var(--line) 70%, var(--paper) 30%);
    flex: 1;
  }

  :where(.scroll-area-corner) {
    background: color-mix(in oklab, var(--line) 60%, transparent);
  }
}

/* packages/ui/src/styles/blocks/checkbox.css */
@layer components {
  .checkbox {
    appearance: none;
    display: inline-flex;
    inline-size: var(--control-2xs);
    block-size: var(--control-2xs);
    border: 1px solid var(--checkbox-border, var(--line));
    border-radius: var(--radius-sm);
    background: var(--paper);
    cursor: pointer;
    transition: all var(--duration) var(--ease);
    justify-content: center;
    align-items:  center;
  }

  .checkbox:hover {
    border-color: var(--checkbox-border-hover, var(--accent));
  }

  .checkbox[data-state="checked"] {
    background: var(--checkbox-bg-checked, var(--accent));
    border-color: var(--checkbox-border-checked, var(--accent));
    color: var(--paper);
  }

  .checkbox:focus-visible {
    outline: 2px solid var(--checkbox-outline, var(--accent));
    outline-offset: 2px;
  }

  .checkbox[data-disabled] {
    opacity: .5;
    cursor: not-allowed;
  }

  .checkbox:after {
    content: "";
    opacity: 0;
    border-top: 0;
    border-bottom: 2px solid;
    border-left: 2px solid;
    border-right: 0;
    block-size: .25rem;
    inline-size: .5rem;
    transform: rotate(-45deg);
  }

  .checkbox[data-state="checked"]:after {
    opacity: 1;
  }
}

/* packages/ui/src/styles/blocks/switch.css */
@layer components {
  :where(.switch) {
    appearance: none;
    cursor: pointer;
    position: relative;
    display: inline-block;
    block-size: var(--control-2xs);
    inline-size: calc(var(--control-2xs) * 1.618);
    background: var(--switch-track, var(--line));
    transition: background var(--duration) var(--ease);
    border: none;
    border-radius: 9999px;
    flex-shrink: 0;
    margin: 0;
    padding: 0;
  }

  :where(.switch):after {
    content: "";
    position: absolute;
    inline-size: calc(var(--control-2xs)  - .25rem);
    block-size: calc(var(--control-2xs)  - .25rem);
    background: oklch(1 0 0);
    transition: transform var(--duration) var(--ease);
    border-radius: 50%;
    top: .125rem;
    box-shadow: 0 1px 2px #0003;
    box-shadow: 0 1px 2px color(display-p3 0 0 0 / .2);
    box-shadow: 0 1px 2px lab(0% 0 0 / .2);
  }

  :where(.switch):not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))):after {
    left: .125rem;
  }

  :where(.switch):not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))):after {
    left: .125rem;
  }

  :where(.switch):not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))):after {
    left: .125rem;
  }

  :where(.switch):-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)):after {
    right: .125rem;
  }

  :where(.switch):-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)):after {
    right: .125rem;
  }

  :where(.switch):is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)):after {
    right: .125rem;
  }

  :where(.switch)[aria-checked="true"] {
    background: var(--switch-track-on, var(--accent));
  }

  :where(.switch)[aria-checked="true"]:after {
    transform: translateX(calc(var(--control-2xs) * .618));
  }

  :where(.switch):focus-visible {
    outline: 2px solid var(--switch-outline, var(--accent));
    outline-offset: 2px;
  }

  :where(.switch):disabled {
    opacity: .5;
    cursor: not-allowed;
  }
}

/* packages/ui/src/styles/blocks/avatar.css */
@layer components {
  :where(.avatar) {
    display: inline-flex;
    overflow: hidden;
    border-radius: var(--radius-full);
    inline-size: var(--avatar-size, var(--control-md));
    block-size: var(--avatar-size, var(--control-md));
    background: var(--surface-alt);
    color: var(--ink);
    position: relative;
    justify-content: center;
    align-items:  center;
  }

  :where(.avatar) img {
    object-fit: cover;
    z-index: 1;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.avatar[data-size="sm"]) {
    --avatar-size: var(--control-sm);
  }

  :where(.avatar[data-size="lg"]) {
    --avatar-size: var(--control-lg);
  }

  :where(.avatar[data-size="xl"]) {
    --avatar-size: var(--control-xl);
  }

  :where(.avatar-fallback) {
    display: flex;
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    position: absolute;
    justify-content: center;
    align-items:  center;
    block-size: 100%;
    inline-size: 100%;
  }
}

/* packages/ui/src/styles/blocks/alert.css */
@layer components {
  :where(.alert) {
    position: relative;
    cursor: default;
    display: grid;
    grid-template-columns: 0 1fr;
    gap: var(--space-xs) 0;
    --surface-bg: var(--alert-bg, var(--surface-alt));
    --surface-radius: var(--radius-lg);
    --surface-shadow: none;
    background: var(--surface-bg);
    color: var(--alert-fg, var(--ink));
    border: 1px solid var(--alert-border, var(--line));
    border-radius: var(--surface-radius);
    padding-inline: var(--space-md);
    padding-block: var(--space-sm);
    font-size: var(--text-ui);
    font-weight: var(--weight-normal);
    align-items:  start;
    inline-size: 100%;
  }

  :where(.alert):has( > svg) {
    grid-template-columns: 2rem 1fr;
    column-gap: var(--space-sm);
  }

  :where(.alert) > svg {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    color: currentColor;
    transform: translateY(2px);
  }

  :where(.alert)[data-tone="danger"] {
    --alert-bg: color-mix(in oklab, var(--danger) 10%, var(--paper));
    --alert-fg: var(--danger);
    --alert-border: var(--danger);
  }

  :where(.alert)[data-tone="danger"] [data-slot="alert-description"] {
    opacity: .9;
  }

  :where(.alert)[data-tone="info"] {
    --alert-bg: color-mix(in oklab, var(--accent) 8%, var(--paper));
    --alert-fg: var(--accent);
    --alert-border: color-mix(in oklab, var(--accent) 30%, var(--line));
  }

  :where(.alert)[data-tone="info"] [data-slot="alert-description"] {
    color: var(--ink-muted);
  }

  :where(.alert-title) {
    grid-column-start: 2;
    min-block-size: var(--space-md);
    font-weight: var(--weight-medium);
    letter-spacing: -.01em;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
  }

  :where(.alert-description) {
    grid-column-start: 2;
    color: var(--muted);
    display: grid;
    justify-items: start;
    gap: var(--space-xs);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
  }
}

/* packages/ui/src/styles/blocks/alert-banner.css */
@layer components {
  :where(.alert-banner-stack) {
    position: fixed;
    top: var(--space-sm);
    inset-inline: var(--space-sm);
    z-index: calc(var(--z-modal)  + 1);
    display: flex;
    gap: var(--space-xs);
    pointer-events: none;
    flex-direction: column;
  }

  :where(.alert-banner) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding-block: var(--space-xs);
    padding-inline: var(--space-md);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    pointer-events: auto;
    border-radius: var(--radius-md);
    border: 1px solid var(--banner-border);
    box-shadow: var(--shadow-md);
    --banner-bg: color-mix(in oklab, var(--accent) 15%, var(--paper));
    --banner-border: color-mix(in oklab, var(--accent) 28%, transparent);
    background: var(--banner-bg);
    color: var(--ink);
  }

  :where(.alert-banner[data-tone="warning"]) {
    --banner-bg: color-mix(in oklab, var(--warning) 15%, var(--paper));
    --banner-border: color-mix(in oklab, var(--warning) 28%, transparent);
  }

  :where(.alert-banner[data-tone="danger"]) {
    --banner-bg: color-mix(in oklab, var(--danger) 15%, var(--paper));
    --banner-border: color-mix(in oklab, var(--danger) 28%, transparent);
  }

  :where(.alert-banner[data-tone="positive"]) {
    --banner-bg: color-mix(in oklab, var(--positive) 15%, var(--paper));
    --banner-border: color-mix(in oklab, var(--positive) 28%, transparent);
  }

  :where(.alert-banner-icon) {
    display: flex;
    color: currentColor;
    opacity: .7;
    flex-shrink: 0;
  }

  :where(.alert-banner-body) {
    flex: 1;
    min-inline-size: 0;
  }

  :where(.alert-banner-title) {
    font-weight: var(--weight-semibold);
  }

  :where(.alert-banner-message) {
    color: var(--muted);
    margin-inline-start: var(--space-xs);
  }

  :where(.alert-banner-actions) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    flex-shrink: 0;
  }

  :where(.alert-banner-link) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    text-decoration: underline;
    text-underline-offset: 2px;
    color: inherit;
    white-space: nowrap;
  }

  :where(.alert-banner-link):hover {
    opacity: .8;
  }

  :where(.alert-banner-dismiss) {
    display: flex;
    padding: var(--space-2xs);
    color: inherit;
    cursor: pointer;
    border-radius: var(--radius-sm);
    opacity: .6;
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
  }

  :where(.alert-banner-dismiss):hover {
    opacity: 1;
    background: color-mix(in oklab, var(--ink) 6%, transparent);
  }

  :where(.alert-banner-pager) {
    display: flex;
    align-items:  center;
    gap: 1px;
    margin-inline-end: var(--space-2xs);
  }

  :where(.alert-banner-pager-btn) {
    display: flex;
    padding: var(--space-2xs);
    color: inherit;
    cursor: pointer;
    border-radius: var(--radius-sm);
    opacity: .6;
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
  }

  :where(.alert-banner-pager-btn):hover {
    opacity: 1;
    background: color-mix(in oklab, var(--ink) 6%, transparent);
  }

  :where(.alert-banner-pager-count) {
    font-size: var(--text-caption);
    font-variant-numeric: tabular-nums;
    opacity: .6;
    text-align: center;
    min-inline-size: 2.5ch;
  }
}

/* packages/ui/src/styles/blocks/auth.css */
@layer components {
  :where(.auth-loading) {
    min-block-size: 100vh;
    display: grid;
    background: var(--surface);
    place-items:  center;
    min-block-size: 100dvh;
  }

  :where(.auth-transition) {
    min-block-size: 100vh;
    display: grid;
    place-items:  center;
    gap: var(--space-md);
    padding: var(--space-lg);
    background: var(--surface);
    color: var(--ink-muted);
    text-align: center;
    min-block-size: 100dvh;
  }

  :where(.auth-transition) :where(p) {
    font-size: var(--text-base);
    color: var(--muted);
    opacity: 0;
    animation: auth-transition-fade-in .3s ease .4s forwards;
    max-inline-size: 28rem;
  }

  @keyframes auth-transition-fade-in {
    to {
      opacity: 1;
    }
  }

  :where(.auth-gate) {
    position: relative;
    z-index: 1;
    min-block-size: 100vh;
    display: grid;
    padding: var(--space-xl) var(--space-lg);
    background: linear-gradient(135deg, color-mix(in oklab, var(--surface) 95%, transparent), transparent), radial-gradient(circle at top left, color-mix(in oklab, var(--accent) 18%, transparent), transparent 55%);
    place-items:  center;
    min-block-size: 100dvh;
  }

  :where(.gate-backdrop-content) :where(.auth-gate) {
    background: none;
  }

  :where(.auth-gate) {
    background: none;
    place-items: stretch;
    inline-size: 100%;
    padding: 0;
  }

  :where(.gate-backdrop-content) :where(.auth-gate) {
    background: none;
  }

  :where(.auth-card) {
    --surface-bg: transparent;
    --surface-shadow: none;
    --card-padding: max(var(--space-lg), 4rem);
    box-shadow: none;
    backdrop-filter: none;
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-md);
    background: none;
    border-radius: 0;
    flex-direction: column;
    min-block-size: 100dvh;
    inline-size: 100%;
    max-inline-size: none;
    padding-block-start: max(var(--space-xl), env(safe-area-inset-top, 0));
    padding-block-end: max(var(--space-lg), env(safe-area-inset-bottom, 0));
  }

  :where(.auth-card) > :where([data-slot="card-header"]) {
    inline-size: min(30rem, 100%);
  }

  :where(.auth-card) > :where([data-slot="card-content"]) {
    inline-size: min(30rem, 100%);
  }

  [data-theme="dark"] .auth-card {
    background: linear-gradient(#000000bf 0%, #0009 12%, #0000004d 25%, #0000 40% 55%, #00000059 65%, #000000a6 80%, #000c 100%);
    background: linear-gradient(lab(0% 0 0 / .75) 0%, lab(0% 0 0 / .6) 12%, lab(0% 0 0 / .3) 25%, #0000 40% 55%, lab(0% 0 0 / .35) 65%, lab(0% 0 0 / .65) 80%, lab(0% 0 0 / .8) 100%);
  }

  @media (prefers-color-scheme: dark) {
    :root:not([data-theme]) .auth-card {
      background: linear-gradient(#000000bf 0%, #0009 12%, #0000004d 25%, #0000 40% 55%, #00000059 65%, #000000a6 80%, #000c 100%);
      background: linear-gradient(lab(0% 0 0 / .75) 0%, lab(0% 0 0 / .6) 12%, lab(0% 0 0 / .3) 25%, #0000 40% 55%, lab(0% 0 0 / .35) 65%, lab(0% 0 0 / .65) 80%, lab(0% 0 0 / .8) 100%);
    }
  }

  :where(.gate-backdrop-content) :where(.auth-card) {
    --surface-bg: transparent;
    backdrop-filter: none;
  }

  :where(.auth-card) :where([data-slot="card-header"]) {
    box-shadow: none;
    backdrop-filter: none;
    text-align: center;
    background: none;
    border: 0;
    padding: 0;
  }

  .auth-card [data-slot="card-title"] {
    letter-spacing: -.025em;
    color: var(--ink);
    text-wrap: balance;
    font-size: clamp(1.25rem, 5vw, 2rem);
    line-height: 1;
  }

  [data-theme="dark"] .auth-card [data-slot="card-title"] {
    text-shadow: 0 1px 2px #0009, 0 2px 8px #00000080, 0 0 24px #0006;
    text-shadow: 0 1px 2px color(display-p3 0 0 0 / .6), 0 2px 8px color(display-p3 0 0 0 / .5), 0 0 24px color(display-p3 0 0 0 / .4);
    text-shadow: 0 1px 2px lab(0% 0 0 / .6), 0 2px 8px lab(0% 0 0 / .5), 0 0 24px lab(0% 0 0 / .4);
  }

  @media (prefers-color-scheme: dark) {
    :root:not([data-theme]) .auth-card [data-slot="card-title"] {
      text-shadow: 0 1px 2px #0009, 0 2px 8px #00000080, 0 0 24px #0006;
      text-shadow: 0 1px 2px color(display-p3 0 0 0 / .6), 0 2px 8px color(display-p3 0 0 0 / .5), 0 0 24px color(display-p3 0 0 0 / .4);
      text-shadow: 0 1px 2px lab(0% 0 0 / .6), 0 2px 8px lab(0% 0 0 / .5), 0 0 24px lab(0% 0 0 / .4);
    }
  }

  :where(.auth-card) :where([data-slot="card-description"]) {
    display: none;
  }

  :where(.auth-card) :where([data-slot="card-content"]) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    margin-block-start: 0;
    padding: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where([data-slot="card-content"]) {
    gap: 0;
  }

  :where(.auth-form) {
    gap: var(--space-md);
  }

  .auth-card .auth-tabs-list {
    display: flex;
    padding: var(--space-2xs);
    --auth-trigger-radius: calc(var(--radius-lg) * 1.25 - var(--space-2xs));
    background: color-mix(in oklab, var(--surface) 50%, transparent);
    border: 1px solid color-mix(in oklab, var(--ink) 12%, transparent);
    backdrop-filter: blur(24px) saturate(150%);
    -webkit-backdrop-filter: blur(24px) saturate(150%);
    box-shadow: inset 0 1px 0 color-mix(in oklab, var(--ink) 6%, transparent);
    border-block-end: 0;
    block-size: auto;
    min-block-size: 3.25rem;
    inline-size: 100%;
    margin-block-end: 0;
  }

  .auth-card .auth-tabs-list:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: calc(var(--radius-lg) * 1.25);
    border-top-right-radius: calc(var(--radius-lg) * 1.25);
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
  }

  .auth-card .auth-tabs-list:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: calc(var(--radius-lg) * 1.25);
    border-top-right-radius: calc(var(--radius-lg) * 1.25);
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
  }

  .auth-card .auth-tabs-list:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: calc(var(--radius-lg) * 1.25);
    border-top-right-radius: calc(var(--radius-lg) * 1.25);
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
  }

  .auth-card .auth-tabs-list:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-right-radius: calc(var(--radius-lg) * 1.25);
    border-top-left-radius: calc(var(--radius-lg) * 1.25);
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
  }

  .auth-card .auth-tabs-list:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-right-radius: calc(var(--radius-lg) * 1.25);
    border-top-left-radius: calc(var(--radius-lg) * 1.25);
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
  }

  .auth-card .auth-tabs-list:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-right-radius: calc(var(--radius-lg) * 1.25);
    border-top-left-radius: calc(var(--radius-lg) * 1.25);
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
  }

  .auth-card .auth-tabs-list [data-slot="tabs-trigger"] {
    border-radius: var(--auth-trigger-radius);
  }

  :where(.auth-fieldset) {
    display: block;
    overflow: hidden;
    background: color-mix(in oklab, var(--surface) 50%, transparent);
    border: 1px solid color-mix(in oklab, var(--ink) 12%, transparent);
    border-radius: calc(var(--radius-lg) * 1.25);
    backdrop-filter: blur(24px) saturate(150%);
    -webkit-backdrop-filter: blur(24px) saturate(150%);
    box-shadow: inset 0 1px 0 color-mix(in oklab, var(--ink) 6%, transparent), var(--shadow-md);
    transition: border-color var(--duration) var(--ease), background var(--duration) var(--ease);
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-fieldset) {
    box-shadow: var(--shadow-md);
    border-block-start: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-fieldset):not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-fieldset):not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-fieldset):not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-fieldset):-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-fieldset):-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-fieldset):is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-fieldset):before {
    content: "";
    position: absolute;
    background: color-mix(in oklab, var(--ink) 10%, transparent);
    pointer-events: none;
    block-size: 1px;
    top: 0;
    left: 0;
    right: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-fieldset) {
    position: relative;
  }

  :where(.auth-fieldset):focus-within {
    border-color: color-mix(in oklab, var(--accent) 45%, transparent);
    background: color-mix(in oklab, var(--surface) 60%, transparent);
  }

  .auth-card:has(.auth-fieldset:focus-within) .auth-tabs-list {
    border-color: color-mix(in oklab, var(--accent) 45%, transparent);
    background: color-mix(in oklab, var(--surface) 60%, transparent);
  }

  :where(.auth-fieldset) :where(.auth-field) {
    position: relative;
    gap: 0;
  }

  :where(.auth-fieldset) :where(.auth-field) + :where(.auth-field):before {
    content: "";
    position: absolute;
    background: color-mix(in oklab, var(--ink) 10%, transparent);
    pointer-events: none;
    block-size: 1px;
    top: 0;
    left: 0;
    right: 0;
  }

  :where(.auth-fieldset) :where(.label) {
    position: absolute;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0;
    block-size: 1px;
    inline-size: 1px;
    margin: -1px;
    padding: 0;
  }

  :where(.auth-fieldset) :where(.auth-field-consent) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding-inline: var(--space-md);
    padding-block: var(--space-sm);
    color: var(--muted);
    font-size: var(--text-ui);
    flex-direction: row;
    min-block-size: 3.25rem;
  }

  :where(.auth-fieldset) :where(.auth-field-consent) :where(.label) {
    position: static;
    overflow: visible;
    clip: auto;
    white-space: normal;
    color: inherit;
    cursor: pointer;
    block-size: auto;
    inline-size: auto;
    margin: 0;
    padding: 0;
  }

  :where(.auth-fieldset) :where(.input) {
    padding-inline: var(--space-md);
    padding-block: var(--space-sm);
    font-size: var(--text-base);
    background: none;
    border: 0;
    border-radius: 0;
    min-block-size: 3.25rem;
  }

  :where(.auth-fieldset) :where(.input):hover:not(:disabled) {
    border-color: #0000;
  }

  :where(.auth-fieldset) :where(.input):focus {
    outline: none;
    box-shadow: none;
    background: color-mix(in oklab, var(--accent) 8%, transparent);
  }

  :where(.auth-fieldset) :where(.input)::placeholder {
    color: color-mix(in oklab, var(--ink) 45%, transparent);
  }

  :where(.auth-fieldset) :where(.input):disabled {
    background: none;
  }

  :where(.auth-fieldset) :where(.input)[aria-invalid="true"] {
    background: color-mix(in oklab, var(--danger) 8%, transparent);
  }

  :where(.auth-actions) {
    gap: var(--space-sm);
    margin-block-start: calc(var(--space-md) * -.5);
  }

  :where(.auth-actions) :where(.button) {
    border-radius: calc(var(--radius-lg) * 1.25);
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    min-block-size: 3.25rem;
    inline-size: 100%;
  }

  :where(.auth-actions) :where(.button:not([data-variant])) {
    background: color-mix(in oklab, var(--accent) 60%, transparent);
    backdrop-filter: blur(16px) saturate(160%);
    -webkit-backdrop-filter: blur(16px) saturate(160%);
    box-shadow: inset 0 1px 0 #ffffff4d, var(--shadow-md);
  }

  @supports (color: color(display-p3 0 0 0)) {
    :where(.auth-actions) :where(.button:not([data-variant])) {
      box-shadow: inset 0 1px 0 color(display-p3 1 1 1 / .3), var(--shadow-md);
    }
  }

  @supports (color: lab(0% 0 0)) {
    :where(.auth-actions) :where(.button:not([data-variant])) {
      box-shadow: inset 0 1px 0 lab(100% -.0000298023 .0000119209 / .3), var(--shadow-md);
    }
  }

  :where(.auth-actions) :where(.button:not([data-variant])):hover:not(:disabled) {
    background: color-mix(in oklab, var(--accent) 75%, transparent);
  }

  [data-theme="light"] .auth-actions .button:not([data-variant]) {
    background: var(--accent);
  }

  [data-theme="light"] .auth-actions .button:not([data-variant]):hover:not(:disabled) {
    background: var(--accent-hover);
  }

  @media (prefers-color-scheme: light) {
    :root:not([data-theme]) .auth-actions .button:not([data-variant]) {
      background: var(--accent);
    }

    :root:not([data-theme]) .auth-actions .button:not([data-variant]):hover:not(:disabled) {
      background: var(--accent-hover);
    }
  }

  :where(.auth-actions) :where(.button[data-variant]) {
    box-shadow: none;
  }

  :where(.auth-actions-secondary) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-sm);
    flex-wrap: wrap;
    margin-block-start: var(--space-sm);
    padding: 0;
  }

  .auth-actions-secondary .button {
    --button-bg: color-mix(in oklab, var(--paper) 80%, transparent);
    --button-fg: var(--muted);
    min-block-size: initial;
    font-weight: var(--weight-medium);
    inline-size: -moz-fit-content;
    inline-size: fit-content;
  }

  :where(.auth-back) {
    margin-block-end: var(--space-md);
  }

  :where(.auth-magic-link-sent) {
    padding: var(--space-lg);
    background: color-mix(in oklab, var(--surface) 50%, transparent);
    border: 1px solid color-mix(in oklab, var(--ink) 12%, transparent);
    border-radius: calc(var(--radius-lg) * 1.25);
    backdrop-filter: blur(24px) saturate(150%);
    -webkit-backdrop-filter: blur(24px) saturate(150%);
    box-shadow: inset 0 1px 0 color-mix(in oklab, var(--ink) 6%, transparent), 0 1px 2px #00000040;
  }

  @supports (color: color(display-p3 0 0 0)) {
    :where(.auth-magic-link-sent) {
      box-shadow: inset 0 1px 0 color-mix(in oklab, var(--ink) 6%, transparent), 0 1px 2px color(display-p3 0 0 0 / .25);
    }
  }

  @supports (color: lab(0% 0 0)) {
    :where(.auth-magic-link-sent) {
      box-shadow: inset 0 1px 0 color-mix(in oklab, var(--ink) 6%, transparent), 0 1px 2px lab(0% 0 0 / .25);
    }
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-magic-link-sent) {
    position: relative;
    border-block-start: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-magic-link-sent):not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-magic-link-sent):not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-magic-link-sent):not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-magic-link-sent):-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-magic-link-sent):-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-magic-link-sent):is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  :where(.auth-card:has(.auth-tabs-list)) :where(.auth-magic-link-sent):before {
    content: "";
    position: absolute;
    background: color-mix(in oklab, var(--ink) 10%, transparent);
    pointer-events: none;
    block-size: 1px;
    top: 0;
    left: 0;
    right: 0;
  }

  :where(.auth-card-loading) {
    display: grid;
    place-items:  center;
    gap: var(--space-sm);
    padding-block: var(--space-xl);
    color: var(--muted);
  }

  :where(.auth-form) {
    display: grid;
    gap: var(--space-md);
  }

  :where(.auth-field) {
    display: grid;
    gap: var(--space-xs);
  }

  :where(.auth-field[data-layout="inline"]) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    flex-direction: row;
  }

  :where(.auth-actions) {
    display: grid;
    gap: var(--space-sm);
    margin-block-start: var(--space-md);
  }

  :where(.auth-link) {
    cursor: pointer;
    color: var(--accent);
    text-decoration: underline;
    font: inherit;
    font-weight: var(--weight-semibold);
    background: none;
    border: none;
    margin-inline-start: var(--space-xs);
    padding: 0;
  }

  :where(.auth-error) {
    color: var(--danger);
    font-size: var(--text-ui);
  }

  :where(.auth-notice) {
    color: var(--muted);
    font-size: var(--text-ui);
  }

  :where(.auth-denied) {
    display: flex;
    text-align: center;
    align-items:  center;
    gap: var(--space-md);
    flex-direction: column;
    max-inline-size: 20rem;
  }

  :where(.auth-denied-icon) {
    display: grid;
    border-radius: var(--radius-full);
    background: color-mix(in oklab, var(--danger) 12%, transparent);
    color: var(--danger);
    place-items:  center;
    block-size: 4rem;
    inline-size: 4rem;
  }

  :where(.auth-denied-icon) :where(svg) {
    block-size: 2rem;
    inline-size: 2rem;
  }

  :where(.auth-denied-title) {
    font-size: var(--text-xl);
    font-weight: var(--weight-semibold);
    color: var(--ink);
    margin: 0;
  }

  :where(.auth-denied-description) {
    font-size: var(--text-lg);
    color: var(--muted);
    margin: 0;
  }

  :where(.auth-denied-help) {
    font-size: var(--text-ui);
    color: var(--muted);
    margin: 0;
    margin-block-end: var(--space-sm);
  }

  :where(.auth-email-display) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.auth-email-display-value) {
    color: var(--muted);
    font-size: var(--text-ui);
    flex: 1;
  }

  :where(.auth-email-change) {
    display: grid;
    gap: var(--space-sm);
  }

  :where(.auth-password-change) {
    display: grid;
    gap: var(--space-sm);
  }

  :where(.auth-email-change-actions) {
    display: flex;
    justify-content: flex-end;
    gap: var(--space-sm);
  }

  :where(.auth-back) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-xs);
    color: var(--muted);
    font-size: var(--text-ui);
    cursor: pointer;
    transition: color var(--duration) var(--ease);
    background: none;
    border: none;
    margin-block-end: var(--space-sm);
    padding: 0;
  }

  :where(.auth-back):hover {
    color: var(--ink);
  }

  :where(.auth-tabs-list) {
    inline-size: 100%;
    margin-block-end: var(--space-lg);
  }

  :where(.auth-tabs-list) :where([data-slot="tabs-trigger"]) {
    flex: 1;
  }

  :where(.auth-magic-link-sent) {
    display: grid;
    gap: var(--space-md);
  }

  :where(.auth-magic-link-sent) :where(.auth-notice) {
    margin: 0;
  }

  :where(.auth-subscription-zone) {
    border-block-start: 1px solid var(--line);
    padding-block-start: var(--space-lg);
  }

  :where(.auth-subscription-status) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.auth-subscription-period) {
    font-size: var(--text-ui);
    color: var(--muted);
  }

  :where(.auth-privacy-zone) {
    border-block-start: 1px solid var(--line);
    padding-block-start: var(--space-lg);
  }

  :where(.auth-collapsible-trigger) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-sm);
    inline-size: 100%;
  }

  :where(.auth-collapsible-chevron) {
    color: var(--muted);
    transition: transform var(--duration) var(--ease);
    flex-shrink: 0;
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.collapsible-trigger)[data-state="open"] :where(.auth-collapsible-chevron) {
    transform: rotate(90deg);
  }

  :where(.auth-collapsible-body) {
    padding-block-start: var(--space-sm);
  }

  :where(.auth-panel-exports) {
    display: flex;
    gap: var(--space-xs);
    border-block-start: 1px solid var(--line);
    flex-direction: column;
    padding-block-start: var(--space-md);
  }

  :where(.auth-export-entry) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-sm);
    padding-block: var(--space-xs);
  }

  :where(.auth-export-entry-meta) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.auth-danger-zone) {
    border-block-start: 1px solid var(--line);
    padding-block-start: var(--space-lg);
  }

  :where(.auth-danger-zone) :where(.field-label) {
    color: var(--danger);
  }

  :where(.auth-danger-zone) :where(.auth-collapsible-chevron) {
    color: var(--danger);
    opacity: .6;
  }

  :where(.auth-panel) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.auth-panel-row) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-md);
    padding-block: var(--space-sm);
  }

  :where(.auth-panel-row-inline) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.auth-panel-hint) {
    font-size: var(--text-ui);
    color: var(--muted);
    margin: 0;
  }

  :where(.auth-panel-label) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    color: var(--muted);
    margin: 0;
  }

  :where(.auth-panel-value) {
    font-size: var(--text-ui);
    color: var(--ink);
    margin: 0;
  }

  :where(.auth-panel-profile-header) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
  }

  :where(.auth-panel-display-name) {
    font-size: var(--text-lg);
    font-weight: var(--weight-semibold);
    margin: 0;
    margin-block-end: var(--space-xs);
  }

  :where(.auth-delete-account) {
    display: grid;
    gap: var(--space-sm);
  }

  :where(.auth-avatar-field) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
    inline-size: 100%;
  }

  :where(.avatar-upload) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-md);
  }

  :where(.avatar-upload-display) {
    position: relative;
    border-radius: var(--radius-lg);
    background: var(--surface-alt);
    overflow: hidden;
    display: grid;
    box-shadow: var(--shadow-md);
    flex-shrink: 0;
    place-items:  center;
    block-size: 5rem;
    inline-size: 5rem;
  }

  :where(.avatar-upload-image) {
    object-fit: cover;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.avatar-upload-initials) {
    font-size: var(--text-xl);
    font-weight: var(--weight-semibold);
    color: var(--muted);
    user-select: none;
  }

  :where(.avatar-upload-actions) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
  }

  :where(.crop-viewport-wrapper) {
    display: flex;
    padding-block: var(--space-xs);
    justify-content: center;
  }

  :where(.crop-viewport) {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--surface-alt);
    cursor: grab;
    touch-action: none;
    outline-offset: 2px;
    block-size: 300px;
    inline-size: 300px;
  }

  :where(.crop-viewport):active {
    cursor: grabbing;
  }

  :where(.crop-viewport):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.crop-circle-overlay) {
    position: absolute;
    pointer-events: none;
    border-radius: var(--radius-sm);
    background: radial-gradient(circle, #0000 48.5%, #00000061 49.5%);
    background: radial-gradient(circle, #0000 48.5%, lab(0% 0 0 / .38) 49.5%);
    inset: 0;
  }

  :where(.crop-zoom-wheel) {
    position: absolute;
    top: var(--space-sm);
    cursor: ew-resize;
    touch-action: none;
    z-index: 1;
    display: flex;
    align-items:  center;
    gap: var(--space-2xs);
    flex-direction: column;
    inline-size: -moz-fit-content;
    inline-size: fit-content;
    margin-inline-start: auto;
    margin-inline-end: auto;
    left: 0;
    right: 0;
  }

  :where(.crop-zoom-wheel) :where(svg) {
    display: block;
  }

  :where(.crop-zoom-lines) {
    stroke: oklch(1 0 0);
    stroke-linecap: round;
  }

  :where(.crop-zoom-label) {
    color: oklch(1 0 0);
    opacity: .75;
    font-variant-numeric: tabular-nums;
    letter-spacing: .02em;
    font-size: .625rem;
    line-height: 1;
  }

  :where(.crop-help-grid) {
    display: grid;
    gap: var(--space-xs);
    list-style: none;
    margin: 0;
    padding: 0;
  }

  :where(.crop-help-row) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.crop-help-keys) {
    display: flex;
    align-items:  center;
    gap: var(--space-2xs);
    min-inline-size: 10rem;
    margin: 0;
  }

  :where(.crop-help-desc) {
    font-size: var(--text-ui);
    color: var(--muted);
    margin: 0;
  }

  :where(.crop-dialog-footer) {
    flex-direction: column;
    align-items: stretch;
  }

  :where(.crop-keyboard-btn) {
    position: absolute;
    bottom: var(--space-xs);
    right: var(--space-xs);
    z-index: 1;
    color: oklch(1 0 0);
    opacity: .55;
    transition: opacity var(--duration) var(--ease);
  }

  :where(.crop-keyboard-btn):hover {
    opacity: 1;
  }

  :where(.device-consent-code) {
    display: block;
    font-family: var(--font-mono);
    font-size: var(--text-2xl);
    font-weight: var(--weight-semibold);
    letter-spacing: .18em;
    text-align: center;
    padding-block: var(--space-md);
    margin-block: var(--space-sm);
    border-radius: var(--radius-md);
    background: color-mix(in oklab, var(--accent) 8%, transparent);
    color: var(--ink);
    user-select: all;
  }

  :where(.device-consent-label) {
    color: var(--ink-muted);
    font-size: var(--text-caption);
    text-align: center;
    margin-block-start: var(--space-xs);
  }

  :where(.device-consent-error) {
    color: var(--danger);
    font-size: var(--text-ui);
    margin-block-start: var(--space-sm);
  }
}

@layer overrides {
  .auth-settings-dialog {
    --dialog-max-inline-size: 36rem;
    --dialog-tabs-sidebar-width: 10rem;
  }

  .gate-backdrop-content {
    inline-size: 100%;
    padding: 0;
  }
}

/* packages/ui/src/styles/blocks/empty.css */
@layer components {
  .empty {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-lg);
    border-radius: var(--radius-lg);
    background: var(--surface);
    box-shadow: var(--shadow-card);
    padding: var(--space-lg);
    text-align: center;
    text-wrap: balance;
    container-type: inline-size;
    container-name: empty;
    flex-direction: column;
    flex: 1;
    inline-size: 100%;
    min-inline-size: 0;
    max-inline-size: 48rem;
    margin-inline-start: auto;
    margin-inline-end: auto;
  }

  @container empty (width >= 48rem) {
    .empty {
      padding: var(--space-xl);
    }
  }

  .empty-header {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    text-align: center;
    flex-direction: column;
    max-inline-size: 32rem;
  }

  .empty-media {
    display: flex;
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
    margin-block-end: var(--space-sm);
  }

  .empty-media svg {
    pointer-events: none;
    flex-shrink: 0;
  }

  .empty-media[data-variant="icon"] {
    background: var(--surface-alt);
    color: var(--ink);
    display: flex;
    border-radius: var(--radius-lg);
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
    block-size: 2.5rem;
    inline-size: 2.5rem;
  }

  .empty-media[data-variant="icon"] svg:not([class*="size-"]) {
    block-size: 1.5rem;
    inline-size: 1.5rem;
  }

  .empty-media[data-variant="circle"] {
    background: color-mix(in oklab, var(--muted) 12%, transparent);
    color: var(--muted);
    display: flex;
    border-radius: var(--radius-full);
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
    block-size: 3rem;
    inline-size: 3rem;
  }

  .empty-media[data-variant="circle"] svg:not([class*="size-"]) {
    block-size: 1.5rem;
    inline-size: 1.5rem;
  }

  .empty-title {
    font-size: var(--text-lg);
    line-height: 1.75;
    font-weight: var(--weight-medium);
    letter-spacing: -.01em;
  }

  .empty-description {
    color: var(--muted);
    font-size: var(--text-ui);
    line-height: 1.75;
  }

  .empty-description > a {
    text-decoration: underline;
    text-underline-offset: var(--space-xs);
  }

  .empty-description > a:hover {
    color: var(--accent);
  }

  .empty-content {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    text-wrap: balance;
    flex-direction: column;
    inline-size: 100%;
    min-inline-size: 0;
    max-inline-size: 32rem;
  }
}

/* packages/ui/src/styles/blocks/content-breadcrumb.css */
@layer components {
  @keyframes content-breadcrumb-line-reveal {
    from {
      opacity: 0;
    }

    to {
      opacity: 1;
    }
  }

  :where(.content-breadcrumb-separator) {
    color: var(--muted);
    font-size: var(--text-ui);
    flex-shrink: 0;
    line-height: 1;
  }

  :where(.content-breadcrumb-trigger) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-2xs);
    padding-inline: var(--space-sm);
    padding-block: var(--space-xs);
    color: var(--accent);
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    border-radius: var(--radius-sm);
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    transition: background-color var(--duration) var(--ease);
    background: none;
    border: 0;
    min-inline-size: 0;
    max-inline-size: 100%;
    line-height: 1;
  }

  :where(.content-breadcrumb-trigger):hover {
    background: color-mix(in oklab, var(--ink) 6%, transparent);
  }

  :where(.content-breadcrumb-trigger):focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
  }

  :where(.content-breadcrumb-trigger-current) {
    text-overflow: ellipsis;
    overflow: hidden;
  }

  :where(.content-breadcrumb-trigger-chevron) {
    color: var(--muted);
    flex-shrink: 0;
    block-size: .875rem;
    inline-size: .875rem;
  }

  :where(.content-breadcrumb-sheet) {
    --breadcrumb-path-step: var(--space-md);
  }

  :where(.content-breadcrumb-path) {
    list-style: none;
    display: flex;
    gap: var(--space-2xs);
    padding: 0;
    flex-direction: column;
    margin: 0;
    padding-block-end: max(var(--space-md), var(--safe-area-bottom));
  }

  :where(.content-breadcrumb-path-item) {
    position: relative;
    padding-inline-start: calc(var(--depth, 0) * var(--breadcrumb-path-step));
  }

  :where(.content-breadcrumb-path-item):not(:first-child):before {
    content: "";
    position: absolute;
    left: calc((var(--depth, 0)  - 1) * var(--breadcrumb-path-step)  + var(--space-sm));
    top: calc(-1 * var(--space-2xs));
    block-size: calc(50% + var(--space-2xs));
    background: color-mix(in oklab, var(--ink) 20%, transparent);
    inline-size: 1px;
  }

  :where(.content-breadcrumb-path-item):not(:first-child):after {
    content: "";
    position: absolute;
    left: calc((var(--depth, 0)  - 1) * var(--breadcrumb-path-step)  + var(--space-sm));
    inline-size: calc(var(--breadcrumb-path-step)  - var(--space-sm));
    background: color-mix(in oklab, var(--ink) 20%, transparent);
    block-size: 1px;
    top: 50%;
  }

  :where(.content-breadcrumb-path-link) {
    display: block;
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    border-radius: var(--radius-sm);
    color: var(--ink);
    text-decoration: none;
    font-size: var(--text-ui);
    transition: background-color var(--duration) var(--ease);
  }

  :where(.content-breadcrumb-path-link):hover {
    background: color-mix(in oklab, var(--ink) 6%, transparent);
  }

  :where(.content-breadcrumb-path-current) {
    display: block;
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    border-radius: var(--radius-sm);
    background: color-mix(in oklab, var(--accent) 12%, transparent);
    color: var(--accent);
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
  }
}

/* packages/ui/src/styles/blocks/tooltip.css */
@keyframes tooltip-out {
  from {
    opacity: 1;
    scale: 1;
  }

  to {
    opacity: 0;
    scale: .96;
  }
}

@layer components {
  :where(.tooltip-root) {
    display: inline-flex;
  }

  :where(.tooltip-positioner) {
    z-index: var(--z-popover);
    pointer-events: none;
  }

  :where(.tooltip) {
    pointer-events: auto;
    background-color: var(--surface);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-card);
    padding-inline: var(--space-sm);
    padding-block: var(--space-xs);
    font-size: var(--text-ui);
    line-height: var(--leading-snug);
    color: var(--ink);
    text-wrap: balance;
    opacity: 1;
    transition: opacity var(--duration) var(--ease), scale var(--duration) var(--ease);
    inline-size: max-content;
    max-inline-size: 20rem;
    scale: 1;
  }

  @starting-style {
    :where(.tooltip) {
      opacity: 0;
      scale: .96;
    }
  }

  :where(.tooltip)[data-ending-style] {
    animation: tooltip-out var(--duration) var(--ease);
  }

  :where(.tooltip)[data-side="top"] {
    transform-origin: bottom center;
  }

  :where(.tooltip)[data-side="bottom"] {
    transform-origin: top center;
  }

  :where(.tooltip)[data-side="left"] {
    transform-origin: center right;
  }

  :where(.tooltip)[data-side="right"] {
    transform-origin: center left;
  }

  @media (hover: none) {
    :where(.tooltip-positioner) {
      display: none;
    }
  }

  :where(.tooltip-arrow) {
    background: var(--surface);
    z-index: var(--z-popover);
    border-radius: 2px;
    block-size: .625rem;
    inline-size: .625rem;
    transform: translateY(calc(-50% - 2px))rotate(45deg);
  }
}

/* packages/ui/src/styles/blocks/copy-to-clipboard.css */
@layer components {
  :where(.copy-to-clipboard) {
    position: relative;
    display: inline-flex;
  }

  :where(.copy-to-clipboard-trigger) {
    all: unset;
    display: inline-flex;
    cursor: copy;
    border-radius: var(--radius-sm);
    transition: background-color var(--duration) var(--ease);
    align-items:  center;
  }

  :where(.copy-to-clipboard-trigger):hover {
    background-color: var(--tint);
  }

  :where(.copy-to-clipboard-trigger):focus-visible {
    outline: 2px solid var(--ring);
    outline-offset: 2px;
  }

  :where(.copy-to-clipboard-positioner) {
    position: absolute;
    z-index: var(--z-popover);
    pointer-events: none;
  }

  :where(.copy-to-clipboard-positioner)[data-side="top"] {
    padding-block-end: var(--tooltip-offset, 6px);
    bottom: 100%;
    translate: -50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="top"]:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="top"]:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="top"]:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="top"]:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="top"]:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="top"]:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="bottom"] {
    padding-block-start: var(--tooltip-offset, 6px);
    top: 100%;
    translate: -50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="bottom"]:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="bottom"]:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="bottom"]:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="bottom"]:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="bottom"]:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="bottom"]:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="left"] {
    padding-inline-end: var(--tooltip-offset, 6px);
    top: 50%;
    translate: 0 -50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="left"]:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: 100%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="left"]:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: 100%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="left"]:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: 100%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="left"]:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: 100%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="left"]:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: 100%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="left"]:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: 100%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="right"] {
    padding-inline-start: var(--tooltip-offset, 6px);
    top: 50%;
    translate: 0 -50%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="right"]:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 100%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="right"]:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 100%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="right"]:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: 100%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="right"]:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 100%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="right"]:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 100%;
  }

  :where(.copy-to-clipboard-positioner)[data-side="right"]:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: 100%;
  }

  :where(.copy-to-clipboard-bubble) {
    display: block;
    pointer-events: none;
    white-space: nowrap;
    background-color: var(--surface);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-card);
    padding-inline: var(--space-sm);
    padding-block: var(--space-xs);
    font-size: var(--text-ui);
    line-height: var(--leading-snug);
    color: var(--positive);
    opacity: 1;
    transition: opacity var(--duration) var(--ease), scale var(--duration) var(--ease);
    inline-size: max-content;
    scale: 1;
  }

  @starting-style {
    :where(.copy-to-clipboard-bubble) {
      opacity: 0;
      scale: .96;
    }
  }

  :where(.copy-to-clipboard-bubble)[data-side="top"] {
    transform-origin: bottom center;
  }

  :where(.copy-to-clipboard-bubble)[data-side="bottom"] {
    transform-origin: top center;
  }

  :where(.copy-to-clipboard-bubble)[data-side="left"] {
    transform-origin: center right;
  }

  :where(.copy-to-clipboard-bubble)[data-side="right"] {
    transform-origin: center left;
  }
}

/* packages/ui/src/styles/blocks/truncate.css */
@layer components {
  :where(.truncate) {
    display: block;
    overflow: hidden;
    min-inline-size: 0;
  }

  :where(.tooltip-root):has(.truncate) {
    display: block;
    min-inline-size: 0;
  }

  :where(.truncate[data-scrollable]) {
    overflow-x: auto;
    scrollbar-width: none;
  }

  :where(.truncate-inner) {
    display: block;
    white-space: nowrap;
  }

  :where(.truncate[data-truncated][data-fade="end"] .truncate-inner):after {
    content: "";
    display: inline-block;
    inline-size: var(--truncate-fade, var(--space-lg));
  }

  :where(.truncate[data-truncated][data-fade="both"] .truncate-inner):after {
    content: "";
    display: inline-block;
    inline-size: var(--truncate-fade, var(--space-lg));
  }

  :where(.truncate[data-truncated][data-fade="start"] .truncate-inner):before {
    content: "";
    display: inline-block;
    inline-size: var(--truncate-fade, var(--space-lg));
  }

  :where(.truncate[data-truncated][data-fade="both"] .truncate-inner):before {
    content: "";
    display: inline-block;
    inline-size: var(--truncate-fade, var(--space-lg));
  }

  :where(.truncate[data-truncated]:not([data-scrollable])[data-fade="end"] .truncate-inner) {
    mask-image: linear-gradient(to right, black calc(100% - var(--truncate-fade, var(--space-lg))), transparent 100%);
  }

  :where(.truncate[data-truncated]:not([data-scrollable])[data-fade="start"] .truncate-inner) {
    mask-image: linear-gradient(to left, black calc(100% - var(--truncate-fade, var(--space-lg))), transparent 100%);
  }

  :where(.truncate[data-truncated]:not([data-scrollable])[data-fade="both"] .truncate-inner) {
    mask-image: linear-gradient(to right, transparent 0, black var(--truncate-fade, var(--space-lg)), black calc(100% - var(--truncate-fade, var(--space-lg))), transparent 100%);
  }

  :where(.truncate[data-truncated][data-scrollable][data-fade="end"]) {
    mask-image: linear-gradient(to right, black calc(100% - var(--truncate-fade, var(--space-lg))), transparent 100%);
  }

  :where(.truncate[data-truncated][data-scrollable][data-fade="start"]) {
    mask-image: linear-gradient(to left, black calc(100% - var(--truncate-fade, var(--space-lg))), transparent 100%);
  }

  :where(.truncate[data-truncated][data-scrollable][data-fade="both"]) {
    mask-image: linear-gradient(to right, transparent 0, black var(--truncate-fade, var(--space-lg)), black calc(100% - var(--truncate-fade, var(--space-lg))), transparent 100%);
  }
}

/* packages/ui/src/styles/blocks/collapsible.css */
@layer components {
  :where(.collapsible-trigger) {
    cursor: pointer;
    font: inherit;
    color: inherit;
    text-align: inherit;
    display: inline-flex;
    align-items:  center;
    gap: var(--space-2xs);
    background: none;
    border: none;
    padding: 0;
  }

  :where(.collapsible-trigger)[data-disabled] {
    pointer-events: none;
    opacity: .5;
  }

  .collapsible-chevron {
    color: var(--accent);
    transition: rotate var(--duration) var(--ease);
    flex-shrink: 0;
  }

  :where(.collapsible-trigger)[data-state="open"] .collapsible-chevron {
    rotate: 90deg;
  }

  :where(.collapsible-content) {
    display: grid;
    grid-template-rows: 0fr;
    overflow: hidden;
    contain: paint;
    transition: grid-template-rows var(--duration) var(--ease);
  }

  :where(.collapsible-content)[data-state="open"] {
    grid-template-rows: 1fr;
  }

  :where(.collapsible-content-inner) {
    overflow: hidden;
    min-height: 0;
  }
}

/* packages/ui/src/styles/blocks/item.css */
@layer components {
  :where(.item-group) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.item-separator) {
    margin-block-start: 0;
    margin-block-end: 0;
  }

  :where(.item) {
    display: flex;
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    border-radius: var(--radius-md);
    transition: colors var(--duration);
    outline: none;
    border: 1px solid #0000;
    flex-wrap: wrap;
    align-items:  center;
  }

  :where(.item):focus-visible {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 50%, transparent);
  }

  :where(.item) a {
    color: inherit;
    text-decoration: none;
  }

  :where(.item) a:hover {
    color: var(--accent);
  }

  .item[data-variant="outline"] {
    border-color: var(--line);
  }

  .item[aria-selected="true"] {
    border-color: var(--accent);
    background: color-mix(in oklab, var(--accent) 8%, transparent);
  }

  .item[data-variant="muted"] {
    background: color-mix(in oklab, var(--surface-alt) 50%, transparent);
  }

  .item[data-size="sm"] {
    padding-block: var(--space-sm);
    padding-inline: var(--space-md);
    gap: var(--space-sm);
  }

  .item[data-size="default"], .item:not([data-size]) {
    padding: var(--space-md);
    gap: var(--space-md);
  }

  .item-media {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-sm);
    flex-shrink: 0;
  }

  .item-media svg {
    pointer-events: none;
  }

  .item:has([data-slot="item-description"]) .item-media {
    align-self:  start;
    transform: translateY(2px);
  }

  .item-media[data-variant="icon"] {
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface-alt);
    block-size: 2rem;
    inline-size: 2rem;
  }

  .item-media[data-variant="icon"] svg:not([class*="size-"]) {
    inline-size: var(--space-md);
    block-size: var(--space-md);
  }

  .item-media[data-variant="image"] {
    border-radius: var(--radius-sm);
    overflow: hidden;
    block-size: 2.5rem;
    inline-size: 2.5rem;
  }

  .item-media[data-variant="image"] img {
    object-fit: cover;
    block-size: 100%;
    inline-size: 100%;
  }

  .item-content {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
    flex: 1;
  }

  .item-content + .item-content {
    flex: none;
  }

  .item-title {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    font-weight: var(--weight-medium);
    inline-size: -moz-fit-content;
    inline-size: fit-content;
  }

  .item-description {
    color: var(--muted);
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    font-weight: var(--weight-normal);
    text-wrap: balance;
    -webkit-box-orient: vertical;
  }

  .item-description > a {
    text-decoration: underline;
    text-underline-offset: var(--space-xs);
  }

  .item-description > a:hover {
    color: var(--accent);
  }

  .item-actions {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  .item-header, .item-footer {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-sm);
    flex-basis: 100%;
  }

  @container list (inline-size <= 30rem) {
    :where(.item) > :where(.item-content) {
      flex-basis: 100%;
    }

    :where(.item) > :where(.item-actions) {
      flex-basis: 100%;
      justify-content: flex-end;
    }
  }
}

/* packages/ui/src/styles/blocks/item-meta.css */
@layer components {
  :where(.item-meta) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    font-size: var(--text-caption);
    flex-wrap: wrap;
    line-height: 1;
  }

  :where(.item-meta-tag) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-2xs);
    color: var(--muted);
    white-space: nowrap;
  }

  :where(.item-meta-tag) + :where(.item-meta-tag):before {
    content: "·";
    color: color-mix(in oklab, var(--muted) 40%, transparent);
    margin-inline-end: var(--space-2xs);
  }

  .item-meta-tag[data-variant="severity"] {
    gap: var(--space-2xs);
  }

  :where(.item-meta-tag) + .item-meta-tag[data-variant="severity"]:before {
    display: none;
  }

  .item-meta-tag[data-variant="severity"]:before {
    content: "";
    border-radius: var(--radius-full);
    background: var(--muted);
    flex-shrink: 0;
    block-size: .375rem;
    inline-size: .375rem;
  }

  .item-meta-tag[data-variant="severity"][data-severity="warning"]:before {
    background: var(--warning);
  }

  .item-meta-tag[data-variant="severity"][data-severity="error"]:before {
    background: var(--danger);
  }

  .item-meta-tag[data-variant="severity"][data-severity="success"]:before {
    background: var(--positive);
  }

  .item-meta-tag[data-variant="severity"][data-severity="info"]:before {
    background: var(--accent);
  }

  .item-meta-tag[data-variant="status"][data-status="active"] {
    color: var(--positive);
  }

  .item-meta-tag[data-variant="status"][data-status="scheduled"] {
    color: var(--warning);
  }

  .item-meta-tag[data-variant="status"][data-status="expired"] {
    color: var(--danger);
  }
}

/* packages/ui/src/styles/blocks/list.css */
@layer components {
  :where(.list) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.list-header) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-sm);
    flex-wrap: wrap;
  }

  :where(.list-title) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    font-size: var(--text-lg);
    font-weight: var(--weight-semibold);
    line-height: var(--leading-tight);
    margin: 0;
  }

  :where(.list-count) {
    font-size: var(--text-ui);
    color: var(--muted);
    font-weight: normal;
  }

  :where(.list-actions) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.list-content) {
    display: flex;
    container-type: inline-size;
    container-name: list;
    flex-direction: column;
  }

  :where(.list-footer) {
    display: flex;
    justify-content: center;
    align-items:  center;
  }

  :where(.list-loading) {
    display: flex;
    padding: var(--space-xl);
    justify-content: center;
    align-items:  center;
  }

  .list[data-variant="connected"] {
    background: color-mix(in oklab, var(--surface) 40%, transparent);
    border: 1px solid color-mix(in oklab, var(--line) 50%, transparent);
    border-radius: var(--radius-lg);
    padding-inline-start: 0;
    padding-inline-end: 0;
    padding-block: var(--space-sm);
  }

  .list[data-variant="connected"] > .list-content > :where([data-slot="item"]) {
    padding-block: var(--space-md);
    padding-inline: var(--space-lg);
    gap: var(--space-sm);
    border-block-end: 1px solid color-mix(in oklab, var(--line) 50%, transparent);
    border-radius: 0;
  }

  .list[data-variant="connected"] > .list-content > :where([data-slot="item"]):last-child {
    border-block-end: none;
  }

  .list[data-variant="connected"] .item-content {
    gap: var(--space-2xs);
  }

  .list[data-variant="separated"] > .list-content {
    gap: var(--space-sm);
  }

  .list[data-variant="separated"] > .list-content > :where([data-slot="item"]) {
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: var(--space-md);
    gap: var(--space-md);
  }

  .list[data-variant="separated"] > .list-content > :where(a) > :where([data-slot="item"]) {
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: var(--space-md);
    gap: var(--space-md);
  }

  .list[data-variant="separated"] > .list-content > :where(a) {
    text-decoration: none;
    color: inherit;
  }

  .list[data-variant="separated"] > .list-content > :where(a) > :where([data-slot="item"]) {
    cursor: pointer;
    transition: border-color var(--duration);
  }

  .list[data-variant="separated"] > .list-content > :where(a):hover > :where([data-slot="item"]) {
    border-color: color-mix(in oklab, var(--accent) 60%, transparent);
  }
}

/* packages/ui/src/styles/blocks/time-display.css */
@layer components {
  :where(.time-display) {
    font-size: var(--text-caption);
    color: var(--muted);
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
  }

  :where(.time-range) {
    font-size: var(--text-caption);
    color: var(--muted);
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
  }

  :where(.time-range) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-2xs);
  }

  :where(.time-range-separator) {
    color: color-mix(in oklab, var(--muted) 50%, transparent);
  }

  :where(.time-range-label) {
    color: color-mix(in oklab, var(--muted) 70%, transparent);
  }
}

/* packages/ui/src/styles/blocks/error-boundary.css */
@layer components {
  :where(.ErrorBoundary) {
    display: flex;
    padding: var(--space-lg);
    justify-content: center;
    align-items:  center;
    min-block-size: 50vh;
  }

  .ErrorBoundary-card {
    inline-size: 100%;
    max-inline-size: 32rem;
  }

  .ErrorBoundary-header {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  .ErrorBoundary-iconWrapper {
    border-radius: var(--radius-full);
    background: color-mix(in oklab, var(--danger) 15%, transparent);
    padding: var(--space-sm);
  }

  .ErrorBoundary-icon {
    block-size: var(--text-2xl);
    inline-size: var(--text-2xl);
    color: var(--danger);
  }

  .ErrorBoundary-titleWrapper {
    display: flex;
    flex-direction: column;
  }

  .ErrorBoundary-title {
    color: var(--ink);
  }

  .ErrorBoundary-description {
    color: var(--muted);
  }

  .ErrorBoundary-content {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  .ErrorBoundary-details {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  .ErrorBoundary-detailSection {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
  }

  .ErrorBoundary-detailTitle {
    font-size: var(--text-ui);
    font-weight: var(--weight-semibold);
    color: var(--muted);
  }

  .ErrorBoundary-codeBlock {
    border-radius: var(--radius-sm);
    background: var(--surface-alt);
    padding: var(--space-sm);
  }

  .ErrorBoundary-code {
    font-family: var(--font-mono);
    font-size: var(--text-ui);
    color: var(--danger);
    word-break: break-word;
  }

  .ErrorBoundary-stackTrace {
    overflow: auto;
    border-radius: var(--radius-sm);
    background: var(--surface-alt);
    padding: var(--space-sm);
    max-block-size: 12rem;
  }

  .ErrorBoundary-pre {
    font-family: var(--font-mono);
    font-size: var(--text-caption);
    color: var(--muted);
    white-space: pre-wrap;
    word-break: break-word;
  }

  .ErrorBoundary-buttonGroup {
    display: flex;
    gap: var(--space-sm);
  }

  .ErrorBoundary-button {
    flex: 1;
  }

  .ErrorBoundary-buttonIcon {
    block-size: 1rem;
    inline-size: 1rem;
    margin-inline-end: var(--space-xs);
  }

  .ErrorBoundary-footer {
    text-align: center;
    font-size: var(--text-ui);
    color: var(--muted);
  }
}

/* packages/ui/src/styles/blocks/not-found.css */
@layer components {
  :where(.NotFound) {
    display: flex;
    padding: var(--space-lg);
    justify-content: center;
    align-items:  center;
    min-block-size: 50vh;
  }

  .NotFound-card {
    inline-size: 100%;
    max-inline-size: 28rem;
  }

  .NotFound-header {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  .NotFound-iconWrapper {
    border-radius: var(--radius-full);
    background: var(--focus-ring);
    padding: var(--space-sm);
  }

  .NotFound-icon {
    block-size: var(--text-2xl);
    inline-size: var(--text-2xl);
    color: var(--accent);
  }

  .NotFound-titleWrapper {
    display: flex;
    flex-direction: column;
  }

  .NotFound-title {
    color: var(--ink);
  }

  .NotFound-description {
    color: var(--muted);
  }

  .NotFound-content {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  .NotFound-buttonGroup {
    display: flex;
    gap: var(--space-sm);
  }

  .NotFound-button {
    flex: 1;
  }

  .NotFound-buttonIcon {
    block-size: 1rem;
    inline-size: 1rem;
    margin-inline-end: var(--space-xs);
  }
}

/* packages/ui/src/styles/blocks/access-gate.css */
@layer components {
  :where(.access-gate) {
    display: flex;
    padding: var(--space-xl) var(--space-md);
    justify-content: center;
    align-items:  center;
  }

  :where(.access-gate-backdrop) {
    position: relative;
    z-index: 1;
    display: flex;
    min-block-size: 100vh;
    padding: var(--space-xl) var(--space-lg);
    background: linear-gradient(135deg, color-mix(in oklab, var(--surface) 95%, transparent), transparent), radial-gradient(circle at top left, color-mix(in oklab, var(--accent) 18%, transparent), transparent 55%);
    justify-content: center;
    align-items:  center;
    min-block-size: 100dvh;
  }

  :where(.access-gate-backdrop) :where(.access-gate) {
    padding: 0;
  }

  :where(.access-gate-card) {
    text-align: center;
    max-inline-size: 28rem;
  }

  :where(.gate-backdrop-content, .access-gate-backdrop) :where(.access-gate-card) {
    --surface-bg: color-mix(in oklab, var(--surface) 85%, transparent);
    backdrop-filter: blur(12px);
  }

  :where(.access-gate-card) :where(.card-header) {
    gap: var(--space-sm);
  }

  :where(.access-gate-icon) {
    display: flex;
    justify-content: center;
    margin-block-end: var(--space-sm);
  }

  :where(.access-gate-icon) :where(svg) {
    color: var(--accent);
    block-size: 3rem;
    inline-size: 3rem;
  }

  :where(.access-gate-content) {
    padding: var(--space-md);
    padding-block-start: var(--space-md);
  }

  :where(.access-gate-features) {
    text-align: start;
    margin-block-end: var(--space-lg);
  }

  :where(.access-gate-features) :where(h3) {
    font-size: var(--text-ui);
    font-weight: var(--weight-semibold);
    margin: 0 0 var(--space-sm) 0;
    color: var(--muted);
  }

  :where(.access-gate-features) :where(ul) {
    list-style: none;
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
    margin: 0;
    padding: 0;
  }

  :where(.access-gate-features) :where(li) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    font-size: var(--text-ui);
  }

  :where(.access-gate-features) :where(li) :where(svg) {
    color: var(--accent);
    flex-shrink: 0;
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.access-gate-pricing) {
    display: flex;
    justify-content: center;
    align-items: baseline;
    gap: var(--space-xs);
    margin-block-end: var(--space-md);
  }

  :where(.access-gate-action) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.access-gate-action) :where(button) {
    padding: var(--space-sm) var(--space-lg);
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--on-accent);
    background: var(--accent);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: opacity var(--duration) var(--ease);
    border: none;
    inline-size: 100%;
  }

  :where(.access-gate-action) :where(a.button) {
    padding: var(--space-sm) var(--space-lg);
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--on-accent);
    background: var(--accent);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: opacity var(--duration) var(--ease);
    border: none;
    inline-size: 100%;
  }

  :where(.access-gate-action) :where(button):hover {
    opacity: .9;
  }

  :where(.access-gate-action) :where(a.button):hover {
    opacity: .9;
  }

  :where(.access-gate-action) :where(button):disabled {
    opacity: .6;
    cursor: not-allowed;
  }

  :where(.access-gate-action) :where(button)[data-loading] {
    opacity: .6;
    cursor: not-allowed;
  }

  :where(.access-gate-action) [data-error] {
    font-size: var(--text-ui);
    color: var(--danger);
    margin: 0;
  }

  :where(.fiber-canvas) {
    position: fixed;
    pointer-events: none;
    inset: 0;
  }

  :where(.fiber-canvas[data-background="true"]) {
    background-image: radial-gradient(120% 95% at 12% 18%, color-mix(in oklab, var(--accent) 11%, transparent), transparent 58%), radial-gradient(90% 80% at 28% 56%, color-mix(in oklab, var(--ink) 8%, transparent), transparent 64%), linear-gradient(135deg, color-mix(in oklab, var(--paper) 96%, black), color-mix(in oklab, var(--paper) 84%, black) 42%, color-mix(in oklab, var(--paper) 72%, black));
  }

  [data-theme="light"] :where(.fiber-canvas[data-background="true"]) {
    background-image: none;
    background-color: var(--paper);
  }

  @media (prefers-color-scheme: light) {
    :root:not([data-theme]) :where(.fiber-canvas[data-background="true"]) {
      background-image: none;
      background-color: var(--paper);
    }
  }

  :where(.fiber-canvas) :where(canvas) {
    display: block;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.gate-backdrop-content) {
    position: relative;
    z-index: 1;
    display: flex;
    min-block-size: 100vh;
    padding: var(--space-xl) var(--space-lg);
    justify-content: center;
    align-items:  center;
    min-block-size: 100dvh;
  }

  @media (max-width: 47.9375rem) {
    :where(.gate-backdrop-content) {
      padding: var(--space-lg) var(--space-md);
      align-items:  start;
    }

    :where(.access-gate-backdrop) {
      padding: var(--space-lg) var(--space-md);
      align-items:  start;
    }
  }

  :where(.gate-backdrop-content) :where(.access-gate) {
    padding: 0;
  }

  :where(.gate-backdrop-theme-toggle) {
    position: fixed;
    top: var(--space-md);
    right: var(--space-md);
    z-index: var(--z-raised);
  }
}

/* packages/ui/src/styles/blocks/tabs.css */
@layer components {
  .tabs {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  .tabs-list {
    display: inline-flex;
    font-size: var(--tabs-font-size, var(--text-ui));
    background: var(--surface-alt);
    color: var(--muted);
    border-radius: .382em;
    justify-content: center;
    align-items:  center;
    block-size: 2.618em;
    inline-size: -moz-fit-content;
    inline-size: fit-content;
    padding: .191em;
  }

  .tabs-trigger {
    display: inline-flex;
    font-size: inherit;
    font-weight: var(--weight-medium);
    white-space: nowrap;
    cursor: pointer;
    transition: all var(--duration) var(--ease);
    color: inherit;
    background: none;
    border: none;
    border-radius: .309em;
    flex: 1;
    justify-content: center;
    align-items:  center;
    gap: .382em;
    block-size: calc(100% - 1px);
    padding-block-start: .382em;
    padding-block-end: .382em;
    padding-inline-start: .809em;
    padding-inline-end: .809em;
  }

  .tabs-trigger[data-disabled] {
    pointer-events: none;
    opacity: .5;
  }

  .tabs-trigger[data-selected="true"] {
    background: var(--paper);
    color: var(--ink);
    box-shadow: var(--shadow-sm);
  }

  .tabs-trigger svg {
    pointer-events: none;
    flex-shrink: 0;
    block-size: 1.272em;
    inline-size: 1.272em;
  }

  .tabs-content {
    outline: none;
    flex: 1;
  }
}

/* packages/ui/src/styles/blocks/toast.css */
@layer components {
  :where(.toast-region) {
    position: fixed;
    z-index: var(--z-toast);
    max-inline-size: calc(100vw - (var(--space-lg) * 2));
    bottom: var(--space-lg);
    right: var(--space-lg);
    pointer-events: none;
    inline-size: 20rem;
  }

  :where(.toast) {
    --toast-scale: calc(1 - (var(--toast-index) * .06));
    --toast-collapsed-opacity: calc(max(.18, 1 - (var(--toast-index) * .22)));
    --toast-vertical-compensation: calc(var(--toast-height, 0px) * (1 - var(--toast-scale)));
    position: absolute;
    box-sizing: border-box;
    padding: var(--space-md);
    transform-origin: center bottom;
    user-select: none;
    cursor: default;
    z-index: calc(var(--z-toast)  - var(--toast-index, 0));
    transform: translateY(calc((var(--toast-collapsed-offset, 0px)  + var(--toast-vertical-compensation, 0px)) * -1)) scale(var(--toast-scale));
    opacity: var(--toast-collapsed-opacity);
    filter: saturate(.88);
    pointer-events: auto;
    display: flex;
    align-items:  flex-start;
    gap: var(--space-sm);
    --surface-shadow: var(--shadow-card), var(--shadow-lg);
    background: var(--surface-bg, var(--surface));
    border-radius: var(--surface-radius, var(--radius-lg));
    box-shadow: var(--surface-shadow);
    color: var(--ink);
    inline-size: 100%;
    transition: transform .35s cubic-bezier(.22,1,.36,1), opacity .35s, filter .35s;
    bottom: 0;
    right: 0;
  }

  :where(.toast)[data-expanded] {
    transform: translateY(calc(var(--toast-expanded-offset, 0px) * -1)) scale(1);
    opacity: 1;
    filter: saturate(1);
  }

  @starting-style {
    :where(.toast) {
      transform: translateY(1.5rem)scale(.94);
      opacity: 0;
    }
  }

  :where(.toast)[data-frontmost] {
    opacity: 1;
    filter: none;
  }

  :where(.toast)[data-state="closing"] {
    opacity: 0;
    pointer-events: none;
    transform: translateY(1.5rem)scale(.96);
  }

  :where(.toast-content) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
    flex: 1;
    align-self:  center;
  }

  :where(.toast-title) {
    font-size: var(--text-ui);
    font-weight: var(--weight-semibold);
    line-height: var(--leading-normal);
  }

  :where(.toast-description) {
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    opacity: .9;
  }

  :where(.toast-actions) {
    display: flex;
    align-self:  flex-end;
    align-items:  center;
    gap: var(--space-xs);
    flex-shrink: 0;
  }

  :where(.toast-action) {
    display: inline-flex;
    padding: var(--space-xs) var(--space-sm);
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    line-height: var(--leading-snug);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background var(--duration), opacity var(--duration);
    border: none;
    justify-content: center;
    align-items:  center;
  }

  :where(.toast-action):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.toast-action-ghost) {
    display: inline-flex;
    padding: var(--space-xs) var(--space-sm);
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    line-height: var(--leading-snug);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background var(--duration), opacity var(--duration);
    border: none;
    justify-content: center;
    align-items:  center;
  }

  :where(.toast-action-ghost):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.toast-action) {
    background: var(--accent);
    color: var(--on-accent);
  }

  :where(.toast-action):hover {
    opacity: .9;
  }

  :where(.toast-close) {
    display: flex;
    border-radius: var(--radius-sm);
    padding: var(--space-xs);
    color: var(--ink);
    opacity: .6;
    cursor: pointer;
    transition: opacity var(--duration);
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
  }

  :where(.toast-close):hover {
    opacity: 1;
  }

  :where(.toast-close):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.toast)[data-tone="positive"] :where(.toast-title) {
    color: var(--positive);
  }

  :where(.toast)[data-tone="danger"] :where(.toast-title) {
    color: var(--danger);
  }

  :where(.toast)[data-tone="warning"] :where(.toast-title) {
    color: var(--warning);
  }

  :where(.toast)[data-kind="notification"] {
    gap: var(--space-sm);
    padding: var(--space-lg);
    flex-direction: column;
  }

  :where(.toast-notification-header) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    inline-size: 100%;
  }

  :where(.toast-notification-icon) {
    color: var(--accent);
  }

  :where(.toast-notification-title) {
    font-size: var(--text-ui);
    font-weight: var(--weight-semibold);
    line-height: var(--leading-normal);
  }

  :where(.toast-notification-body) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
  }

  :where(.toast-notification-body-text) {
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    opacity: .85;
    margin: 0;
  }

  :where(.toast-readmore) {
    display: inline-flex;
    padding: var(--space-2xs) 0;
    color: var(--accent);
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    cursor: pointer;
    transition: opacity var(--duration);
    background: none;
    border: none;
    align-self:  flex-start;
    align-items:  center;
  }

  :where(.toast-readmore):hover {
    opacity: .8;
  }

  :where(.toast-readmore):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
    border-radius: var(--radius-sm);
  }

  :where(.toast-notification-actions) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding-block-start: var(--space-xs);
  }

  :where(.toast-action-ghost) {
    color: var(--accent);
    background: none;
  }

  :where(.toast-action-ghost):hover {
    background: var(--accent-subtle);
  }
}

/* packages/ui/src/styles/blocks/alert-dialog.css */
@media (prefers-reduced-motion: no-preference) {
  @keyframes alert-dialog-fade-in {
    from {
      opacity: 0;
    }

    to {
      opacity: 1;
    }
  }

  @keyframes alert-dialog-fade-out {
    from {
      opacity: 1;
    }

    to {
      opacity: 0;
    }
  }

  @keyframes alert-dialog-zoom-in {
    from {
      opacity: 0;
      transform: scale(.96);
    }

    to {
      opacity: 1;
      transform: scale(1);
    }
  }

  @keyframes alert-dialog-zoom-out {
    from {
      opacity: 1;
      transform: scale(1);
    }

    to {
      opacity: 0;
      transform: scale(.96);
    }
  }
}

@layer components {
  ::view-transition-old(.alert-dialog-backdrop) {
    animation: alert-dialog-fade-out var(--duration) var(--ease);
    animation-fill-mode: both;
  }

  ::view-transition-new(.alert-dialog-backdrop) {
    animation: alert-dialog-fade-in var(--duration) var(--ease);
    animation-fill-mode: both;
  }

  ::view-transition-old(.alert-dialog-popup) {
    animation: alert-dialog-zoom-out var(--duration) var(--ease);
    transform-origin: center;
    animation-fill-mode: both;
  }

  ::view-transition-new(.alert-dialog-popup) {
    animation: alert-dialog-zoom-in var(--duration) var(--ease);
    transform-origin: center;
    animation-fill-mode: both;
  }

  :where(.alert-dialog-backdrop) {
    grid-area: 1 / 1;
    background-color: oklch(0 0 0 / .5);
    place-self: stretch;
  }

  :where(.alert-dialog-popup) {
    --alert-dialog-max-inline-size: 24rem;
    grid-area: 1 / 1;
    z-index: 1;
    display: grid;
    container-type: inline-size;
    container-name: alert-dialog;
    max-inline-size: min(var(--alert-dialog-max-inline-size), calc(100% - var(--space-lg) * 2));
    place-self:  center;
    gap: var(--space-sm);
    inline-size: 100%;
  }

  :where(.alert-dialog-header) {
    display: flex;
    gap: var(--space-sm);
    text-align: center;
    flex-direction: column;
  }

  @container alert-dialog (width >= 40rem) {
    :where(.alert-dialog-header) {
      text-align: start;
    }
  }

  :where(.alert-dialog-footer) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column-reverse;
  }

  @container alert-dialog (width >= 40rem) {
    :where(.alert-dialog-footer) {
      flex-direction: row;
      justify-content: flex-end;
    }
  }

  :where(.alert-dialog-title) {
    font-family: var(--font-body);
    font-size: var(--text-xl);
    line-height: 1;
    font-weight: var(--weight-semibold);
  }

  :where(.alert-dialog-description) {
    color: var(--muted);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
  }
}

/* packages/ui/src/styles/blocks/dialog.css */
@layer components {
  :where(.dialog-container) {
    position: fixed;
    z-index: var(--z-modal);
    display: grid;
    inset: 0;
  }

  :where(.dialog-backdrop) {
    grid-area: 1 / 1;
    background-color: oklch(0 0 0 / .5);
    place-self: stretch;
  }

  @media (prefers-reduced-motion: no-preference) {
    :where(.dialog-backdrop) {
      transition: opacity var(--duration) var(--ease);
    }

    @starting-style {
      :where(.dialog-backdrop) {
        opacity: 0;
      }
    }

    :where(.dialog-backdrop)[data-state="closed"] {
      opacity: 0;
    }
  }

  :where(.dialog-popup) {
    --dialog-padding-block: var(--space-lg);
    --dialog-padding-inline: var(--space-lg);
    --dialog-gap: var(--space-sm);
    --dialog-max-inline-size: 32rem;
    position: relative;
    grid-area: 1 / 1;
    z-index: 1;
    display: flex;
    place-self:  center;
    gap: var(--dialog-gap);
    padding: var(--dialog-padding-block) var(--dialog-padding-inline);
    container-type: inline-size;
    container-name: dialog;
    max-inline-size: min(var(--dialog-max-inline-size), calc(100% - var(--space-lg) * 2));
    max-block-size: calc(100dvh - var(--space-lg) * 2);
    overflow-y: auto;
    flex-direction: column;
    inline-size: 100%;
  }

  @media (prefers-reduced-motion: no-preference) {
    :where(.dialog-popup) {
      transition: opacity var(--duration) var(--ease), filter var(--duration) var(--ease), scale var(--duration) var(--ease);
    }

    @starting-style {
      :where(.dialog-popup) {
        opacity: 0;
        scale: .96;
      }
    }

    :where(.dialog-popup)[data-state="closed"] {
      opacity: 0;
      scale: .96;
    }
  }

  :where(.dialog-container):has( ~ .dialog-container) :where(.dialog-popup, .alert-dialog-popup) {
    pointer-events: none;
    scale: .94;
  }

  :where(.dialog-container):has( ~ .dialog-container ~ .dialog-container) :where(.dialog-popup, .alert-dialog-popup) {
    scale: .88;
  }

  :where(.dialog-popup) > :where(.dialog-close) {
    position: absolute;
    top: calc(var(--dialog-padding-block)  - var(--space-xs));
    right: calc(var(--dialog-padding-inline)  - var(--space-xs));
  }

  :where(.dialog-popup)[data-has-close] :where(.dialog-header-body) {
    padding-inline-end: calc(var(--space-md)  + var(--space-xs)  + var(--space-sm));
  }

  :where(.dialog-close) {
    border-radius: var(--radius-sm);
    opacity: .7;
    cursor: pointer;
    padding: var(--space-xs);
    color: var(--muted);
    display: inline-flex;
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
  }

  @media (prefers-reduced-motion: no-preference) {
    :where(.dialog-close) {
      transition: opacity var(--duration) var(--ease);
    }
  }

  :where(.dialog-close):hover {
    opacity: 1;
    background-color: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dialog-close):focus-visible {
    opacity: 1;
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
    background-color: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dialog-close) > svg {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    pointer-events: none;
    flex-shrink: 0;
  }

  :where(.dialog-header) {
    margin-inline: calc(var(--dialog-padding-inline) * -1);
    display: flex;
    text-align: start;
    padding: var(--dialog-padding-block) var(--dialog-padding-inline) var(--dialog-gap);
    flex-direction: row;
    flex-shrink: 0;
    align-items:  start;
    margin-block-start: calc(var(--dialog-padding-block) * -1);
  }

  :where(.dialog-header-body) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
    flex: 1;
  }

  :where(.dialog-footer) {
    margin-inline: calc(var(--dialog-padding-inline) * -1);
    display: flex;
    gap: var(--space-sm);
    padding: var(--dialog-gap) var(--dialog-padding-inline) var(--dialog-padding-block);
    flex-direction: column-reverse;
    flex-shrink: 0;
    margin-block-end: calc(var(--dialog-padding-block) * -1);
  }

  @container dialog (width >= 20rem) {
    :where(.dialog-footer) {
      flex-direction: row;
      justify-content: flex-end;
    }
  }

  :where(.dialog-bleed) {
    margin-inline: calc(var(--dialog-padding-inline) * -1);
  }

  :where(.dialog-bleed)[data-edges="block"] {
    margin-block: calc(var(--dialog-padding-block) * -1);
  }

  :where(.dialog-bleed)[data-edges="all"] {
    margin: calc(var(--dialog-padding-block) * -1) calc(var(--dialog-padding-inline) * -1);
  }

  :where(.dialog-popup):has(.dialog-body) {
    overflow-y: hidden;
  }

  :where(.dialog-popup):has(.dialog-tabs-layout) {
    overflow-y: hidden;
  }

  :where(.dialog-popup > form) {
    display: flex;
    gap: var(--dialog-gap);
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
  }

  :where(.dialog-body) {
    overflow-y: auto;
    margin-inline: calc(var(--dialog-padding-inline) * -1);
    padding-inline: var(--dialog-padding-inline);
    padding-block: var(--space-sm);
    mask-image: linear-gradient(to bottom, transparent, black var(--space-sm), black calc(100% - var(--space-sm)), transparent);
    flex: 1;
    min-block-size: 0;
  }

  :where(.dialog-title) {
    font-family: var(--font-body);
    font-size: var(--text-2xl);
    line-height: 1;
    font-weight: var(--weight-semibold);
  }

  :where(.dialog-description) {
    color: var(--muted);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
  }

  :where(.dialog-tabs-layout) {
    --dialog-tabs-sidebar-width: 9rem;
    display: grid;
    grid-template-columns: var(--dialog-tabs-sidebar-width) 1fr;
    grid-template-rows: 1fr;
    flex: 1;
    gap: 0;
    min-block-size: 0;
  }

  @container dialog (inline-size <= 28rem) {
    :where(.dialog-tabs-layout) {
      grid-template-columns: 1fr;
      grid-template-rows: auto 1fr;
    }
  }

  :where(.dialog-tabs-list) {
    grid-column: 1;
    grid-row: 1;
    display: flex;
    gap: var(--space-2xs);
    border-inline-end: 1px solid var(--line);
    flex-direction: column;
    margin-block-start: calc(var(--space-xs) * -1);
    margin-inline-start: calc(var(--space-xs) * -1);
    padding-block-start: var(--space-xs);
    padding-inline-start: var(--space-xs);
    padding-inline-end: var(--space-md);
  }

  @container dialog (inline-size <= 28rem) {
    :where(.dialog-tabs-list) {
      grid-column: 1;
      grid-row: 1;
      flex-direction: row;
      overflow-x: auto;
      scrollbar-width: none;
      padding-inline-end: 0;
      padding-block-end: var(--space-xs);
      border-inline-end: none;
      border-block-end: 1px solid var(--line);
      padding-inline: var(--space-xs);
      margin-inline: calc(var(--space-xs) * -1);
    }
  }

  :where(.dialog-tab) {
    display: block;
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-sm);
    color: var(--muted);
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    text-align: start;
    cursor: pointer;
    transition: background var(--duration) var(--ease), color var(--duration) var(--ease);
    background: none;
    border: none;
    flex-shrink: 0;
  }

  :where(.dialog-tab):hover {
    background: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dialog-tab)[aria-selected="true"] {
    background: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dialog-tab)[data-tone="danger"] {
    color: color-mix(in oklab, var(--danger) 55%, var(--muted));
  }

  :where(.dialog-tab)[aria-selected="true"][data-tone="danger"] {
    color: var(--danger);
    background: color-mix(in oklab, var(--danger) 8%, transparent);
  }

  :where(.dialog-tabs-panel-area) {
    grid-column: 2;
    grid-row: 1;
    display: flex;
    overflow-y: auto;
    flex-direction: column;
    min-block-size: 0;
    padding-inline-start: var(--space-lg);
  }

  @container dialog (inline-size <= 28rem) {
    :where(.dialog-tabs-panel-area) {
      grid-column: 1;
      grid-row: 2;
      padding-inline-start: 0;
      padding-block-start: var(--space-md);
    }
  }
}

/* packages/ui/src/styles/blocks/command-palette.css */
@layer components {
  :where(.command-palette-input-wrapper) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-md);
    border-block-end: 1px solid var(--line);
  }

  :where(.command-palette-input-icon) {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    color: var(--muted);
    flex-shrink: 0;
  }

  :where(.command-palette-input) {
    font-size: var(--text-ui);
    color: var(--ink);
    outline: none;
    background: none;
    border: none;
    flex: 1;
  }

  :where(.command-palette-input)::placeholder {
    color: color-mix(in oklab, var(--ink) 30%, var(--paper));
  }

  :where(.command-palette-input-spinner) {
    color: var(--muted);
    flex-shrink: 0;
  }

  :where(.command-palette-kbd) {
    display: inline-flex;
    padding-inline: var(--space-xs);
    padding-block: var(--space-2xs);
    font-size: var(--text-caption);
    font-family: var(--font-mono);
    background: var(--surface-alt);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    color: var(--muted);
    justify-content: center;
    align-items:  center;
    min-inline-size: 1.25rem;
  }

  :where(.command-palette-list) {
    overflow-y: auto;
    padding: var(--space-xs);
    flex: 1;
  }

  :where(.command-palette-list) .empty {
    box-shadow: none;
    background: none;
  }

  :where(.command-palette-group) + .command-palette-group {
    margin-block-start: var(--space-sm);
  }

  :where(.command-palette-group-label) {
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--muted);
  }

  :where(.command-palette-item) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding-block: var(--space-sm);
    padding-inline: var(--space-sm);
    border-radius: var(--radius-sm);
    font-size: var(--text-ui);
    color: var(--ink);
    text-align: start;
    cursor: default;
    outline: none;
    user-select: none;
    background: none;
    border: none;
    inline-size: 100%;
  }

  :where(.command-palette-item)[data-disabled] {
    pointer-events: none;
    opacity: .5;
  }

  :where(.command-palette-item):hover {
    background: var(--surface-alt);
  }

  :where(.command-palette-item):focus {
    background: var(--surface-alt);
  }

  :where(.command-palette-item)[data-active] {
    background: var(--surface-alt);
  }

  :where(.command-palette-item)[data-active] {
    box-shadow: inset 0 0 0 1px var(--line);
  }

  :where(.command-palette-item-icon) {
    display: flex;
    inline-size: var(--space-md);
    block-size: var(--space-md);
    color: var(--muted);
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
  }

  :where(.command-palette-item-icon) svg {
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.command-palette-item-content) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
  }

  :where(.command-palette-item-shortcut) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    flex-shrink: 0;
  }

  :where(.command-palette-separator) {
    margin-block: var(--space-xs);
    background: var(--line);
    block-size: 1px;
  }

  :where(.command-palette-empty) {
    padding: var(--space-lg);
    text-align: center;
    color: var(--muted);
    font-size: var(--text-ui);
  }

  :where(.command-palette-loading) {
    display: flex;
    padding: var(--space-md);
    justify-content: center;
  }
}

@layer overrides {
  .command-palette-panel {
    --surface-radius: var(--radius-lg);
    --surface-shadow: var(--shadow-lg);
    inline-size: min(36rem, calc(100vw - var(--space-lg)));
    display: flex;
    overflow: hidden;
    flex-direction: column;
    place-self:  start center;
    block-size: min(24rem, 60vh);
    margin-block-start: 15vh;
    padding: 0;
    transform: none;
  }
}

/* packages/ui/src/styles/blocks/drawer.css */
@property --drawer-progress {
  syntax: "<number>";
  inherits: true;
  initial-value: 0;
}

@layer components {
  :where(.drawer-container) {
    --drawer-progress: 0;
    position: fixed;
    z-index: var(--z-modal);
    pointer-events: none;
    transition: --drawer-progress .32s cubic-bezier(.32,.72,0,1);
    inset: 0;
  }

  :where(.drawer-container)[data-dragging="true"] {
    transition: none;
  }

  :where(.drawer-backdrop) {
    position: absolute;
    background-color: color-mix(in oklab, var(--paper) 72%, transparent);
    opacity: var(--drawer-progress, 0);
    pointer-events: auto;
    inset: 0;
  }

  :where(.drawer-content) {
    --drawer-radius: clamp(var(--space-sm), 2vw, 1.25rem);
    --drawer-handle-color: color-mix(in oklab, var(--ink) 22%, transparent);
    position: absolute;
    z-index: calc(var(--z-modal)  + 1);
    display: flex;
    background-color: var(--surface);
    box-shadow: var(--shadow-lg);
    outline: none;
    pointer-events: auto;
    container-type: inline-size;
    container-name: dialog;
    flex-direction: column;
  }

  :where(.drawer-content):after {
    content: "";
    position: absolute;
    background-color: var(--surface);
    pointer-events: none;
  }

  :where(.drawer-content)[data-side="bottom"] {
    border-radius: var(--drawer-radius) var(--drawer-radius) 0 0;
    transform: translateY(calc((1 - var(--drawer-progress, 0)) * 100%));
    max-block-size: 96dvh;
    bottom: 0;
    left: 0;
    right: 0;
  }

  :where(.drawer-content)[data-side="bottom"]:after {
    block-size: 100%;
    top: 100%;
    left: 0;
    right: 0;
  }

  :where(.drawer-content)[data-side="top"] {
    border-radius: 0 0 var(--drawer-radius) var(--drawer-radius);
    transform: translateY(calc((var(--drawer-progress, 0)  - 1) * 100%));
    max-block-size: 96dvh;
    top: 0;
    left: 0;
    right: 0;
  }

  :where(.drawer-content)[data-side="top"]:after {
    block-size: 100%;
    bottom: 100%;
    left: 0;
    right: 0;
  }

  :where(.drawer-content)[data-side="right"] {
    border-radius: var(--drawer-radius) 0 0 var(--drawer-radius);
    transform: translateX(calc((1 - var(--drawer-progress, 0)) * 100%));
    inline-size: min(24rem, 92vw);
    top: 0;
    bottom: 0;
    right: 0;
  }

  :where(.drawer-content)[data-side="right"]:after {
    inline-size: 100%;
    top: 0;
    bottom: 0;
    left: 100%;
  }

  :where(.drawer-content)[data-side="left"] {
    border-radius: 0 var(--drawer-radius) var(--drawer-radius) 0;
    transform: translateX(calc((var(--drawer-progress, 0)  - 1) * 100%));
    inline-size: min(24rem, 92vw);
    top: 0;
    bottom: 0;
    left: 0;
  }

  :where(.drawer-content)[data-side="left"]:after {
    inline-size: 100%;
    top: 0;
    bottom: 0;
    right: 100%;
  }

  .drawer-content .drawer-handle {
    display: flex;
    padding-block: var(--space-sm);
    padding-inline: var(--space-md);
    cursor: grab;
    touch-action: none;
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
  }

  .drawer-content .drawer-handle:active {
    cursor: grabbing;
  }

  .drawer-content .drawer-handle:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: var(--space-3xs);
    box-shadow: 0 0 0 4px var(--focus-ring);
    border-radius: var(--radius-sm);
  }

  :where(.drawer-handle-bar) {
    display: block;
    border-radius: var(--radius-full);
    background-color: var(--drawer-handle-color);
    block-size: .3125rem;
    inline-size: 2.5rem;
  }

  .drawer-content[data-side="right"] .drawer-handle, .drawer-content[data-side="left"] .drawer-handle {
    position: absolute;
    display: flex;
    align-items:  center;
    padding-block-start: 0;
    padding-block-end: 0;
    top: 0;
    bottom: 0;
  }

  .drawer-content[data-side="right"] .drawer-handle {
    padding-inline: var(--space-xs);
    left: 0;
  }

  .drawer-content[data-side="left"] .drawer-handle {
    padding-inline: var(--space-xs);
    right: 0;
  }

  .drawer-content[data-side="right"] .drawer-handle-bar, .drawer-content[data-side="left"] .drawer-handle-bar {
    block-size: 2.5rem;
    inline-size: .3125rem;
  }

  :where(.drawer-header) {
    display: flex;
    gap: var(--space-xs);
    padding: var(--space-md) var(--space-lg);
    flex-direction: column;
    flex-shrink: 0;
  }

  :where(.drawer-body) {
    padding: 0 var(--space-lg) var(--space-md);
    overflow-y: auto;
    overscroll-behavior: contain;
    flex: 1;
    min-block-size: 0;
  }

  :where(.drawer-footer) {
    display: flex;
    gap: var(--space-sm);
    padding: var(--space-md) var(--space-lg);
    border-block-start: 1px solid var(--line);
    flex-direction: column;
    flex-shrink: 0;
    padding-block-end: max(var(--space-md), env(safe-area-inset-bottom));
  }

  :where(.drawer-content > form) {
    display: contents;
  }

  :where(.drawer-body-scroll) {
    display: flex;
    gap: var(--space-md);
    padding-inline: var(--space-lg);
    padding-block: var(--space-sm);
    overflow-y: auto;
    overscroll-behavior: contain;
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
  }

  :where(.drawer-content > .dialog-tabs-layout) {
    padding-inline: var(--space-lg);
    padding-block-end: var(--space-md);
  }

  :where(.drawer-content > .dialog-body) {
    padding-inline: var(--space-lg);
    padding-block-end: var(--space-md);
  }

  :where(.drawer-title) {
    color: var(--ink);
    font-size: var(--text-lg);
    font-weight: var(--weight-semibold);
    line-height: var(--leading-snug);
  }

  :where(.drawer-description) {
    color: var(--ink-muted);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
  }

  :where(.drawer-close-button) {
    position: absolute;
    top: var(--space-sm);
    right: var(--space-sm);
    display: inline-flex;
    padding: var(--space-xs);
    border-radius: var(--radius-sm);
    color: var(--ink-muted);
    opacity: .72;
    cursor: pointer;
    transition: opacity var(--duration) var(--ease);
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
  }

  :where(.drawer-close-button):hover {
    opacity: 1;
  }

  :where(.drawer-close-button):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: var(--space-3xs);
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.drawer-close-button) > svg {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    pointer-events: none;
    flex-shrink: 0;
  }

  @media (prefers-reduced-motion: reduce) {
    .drawer-container {
      transition-duration: .01ms !important;
    }

    :where(.drawer-backdrop) {
      transition-duration: .01ms !important;
    }

    :where(.drawer-close-button) {
      transition-duration: .01ms !important;
    }
  }
}

/* packages/ui/src/styles/blocks/drawer-step-host.css */
@layer components {
  :where(.drawer-step-host) {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
  }

  :where(.drawer-step-host-header) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding-inline: var(--space-lg);
    padding-block: var(--space-md) var(--space-sm);
    flex-shrink: 0;
  }

  :where(.drawer-step-host-title) {
    color: var(--ink);
    font-size: var(--text-lg);
    font-weight: var(--weight-semibold);
    line-height: var(--leading-snug);
    margin: 0;
  }

  :where(.drawer-step-host-back) {
    display: inline-flex;
    inline-size: calc(var(--text-ui) * 2);
    block-size: calc(var(--text-ui) * 2);
    border-radius: var(--radius-sm);
    color: var(--ink-muted);
    cursor: pointer;
    outline: none;
    background: none;
    border: none;
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
    padding: 0;
  }

  :where(.drawer-step-host-back):hover {
    color: var(--ink);
    background-color: var(--surface-alt);
  }

  :where(.drawer-step-host-back):focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: var(--space-3xs);
  }

  :where(.drawer-step-host-back) svg {
    inline-size: var(--space-md);
    block-size: var(--space-md);
  }

  :where(.drawer-step-host-viewport) {
    position: relative;
    overflow: hidden;
    flex: 1;
    min-block-size: 0;
    inline-size: 100%;
  }

  :where(.drawer-step-host-track) {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 100%;
    transform: translateX(calc(var(--step-depth, 0) * -100%));
    transition: transform var(--duration) var(--ease);
    inline-size: 100%;
  }

  :where(.drawer-step-host-panel) {
    display: flex;
    flex-direction: column;
    align-self:  start;
    min-inline-size: 0;
  }

  :where(.drawer-step-host-slot) {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
  }

  :where(.drawer-step-host-form) {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
  }

  :where(.drawer-step-host-panel) > :where(.dialog-tabs-layout) {
    padding-inline: var(--space-lg);
    padding-block-end: var(--space-md);
  }

  :where(.drawer-step-host-panel) > :where(.dialog-body) {
    padding-inline: var(--space-lg);
    padding-block-end: var(--space-md);
  }
}

/* packages/ui/src/styles/blocks/dropdown-menu.css */
@layer components {
  @keyframes dropdown-menu-out {
    from {
      opacity: 1;
      transform: scale(1)translateY(0);
    }

    to {
      opacity: 0;
      transform: scale(.95) translateY(calc(var(--space-sm) * -1));
    }
  }

  @keyframes dropdown-menu-in {
    from {
      opacity: 0;
      transform: scale(.95) translateY(calc(var(--space-sm) * -1));
    }

    to {
      opacity: 1;
      transform: scale(1)translateY(0);
    }
  }

  :where(.dropdown-menu) {
    position: relative;
    display: inline-flex;
    align-self:  start;
  }

  :where(.dropdown-menu-content) {
    --surface-radius: var(--radius-md);
    background-color: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--surface-radius);
    box-shadow: var(--surface-shadow);
    color: var(--ink);
    padding: var(--space-xs);
    transform-origin: var(--transform-origin);
    inline-size: max-content;
    min-inline-size: 5rem;
  }

  :where(.dropdown-menu-sub-content) {
    --surface-radius: var(--radius-md);
    background-color: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--surface-radius);
    box-shadow: var(--surface-shadow);
    color: var(--ink);
    padding: var(--space-xs);
    transform-origin: var(--transform-origin);
    inline-size: max-content;
    min-inline-size: 5rem;
  }

  [data-slot="dropdown-menu-positioner"] {
    z-index: var(--z-popover);
  }

  :where(.dropdown-menu-content) {
    z-index: var(--z-popover);
    max-block-size: var(--available-height, 16.375rem);
    overflow: visible;
    animation: dropdown-menu-in var(--duration) var(--ease) both;
  }

  :where(.dropdown-menu-content)[data-state="closing"] {
    animation: dropdown-menu-out var(--duration) var(--ease) both;
  }

  [data-slot="dropdown-menu-slop"] {
    pointer-events: none;
  }

  :where(.dropdown-menu-item) {
    position: relative;
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    border-radius: var(--radius-sm);
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    outline: none;
    cursor: default;
    user-select: none;
    inline-size: 100%;
  }

  :where(.dropdown-menu-item)[data-inset="true"] {
    padding-inline-start: var(--space-lg);
  }

  :where(.dropdown-menu-item)[data-disabled] {
    pointer-events: none;
    opacity: .5;
  }

  :where(.dropdown-menu-item):focus {
    background-color: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dropdown-menu-item)[data-highlighted] {
    background-color: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dropdown-menu-item)[data-tone="danger"] {
    color: var(--danger);
  }

  :where(.dropdown-menu-item)[data-tone="danger"]:focus {
    background-color: color-mix(in oklab, var(--danger) 15%, var(--paper));
    color: var(--danger);
  }

  :where(.dropdown-menu-item)[data-tone="danger"][data-highlighted] {
    background-color: color-mix(in oklab, var(--danger) 15%, var(--paper));
    color: var(--danger);
  }

  :where(.dropdown-menu-item) svg:not([class*="text-"]) {
    color: var(--muted);
    pointer-events: none;
    inline-size: var(--space-md);
    block-size: var(--space-md);
    flex-shrink: 0;
  }

  :where(.dropdown-menu-item)[data-tone="danger"] svg:not([class*="text-"]) {
    color: var(--danger) !important;
  }

  :where(.dropdown-menu-checkbox-item) {
    position: relative;
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    border-radius: var(--radius-sm);
    padding-block: var(--space-xs);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    outline: none;
    cursor: default;
    user-select: none;
    inline-size: 100%;
    padding-inline-start: var(--space-lg);
    padding-inline-end: var(--space-sm);
  }

  :where(.dropdown-menu-checkbox-item)[data-disabled] {
    pointer-events: none;
    opacity: .5;
  }

  :where(.dropdown-menu-checkbox-item):focus {
    background-color: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dropdown-menu-checkbox-item)[data-highlighted] {
    background-color: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dropdown-menu-checkbox-item) svg {
    pointer-events: none;
    inline-size: var(--space-md);
    block-size: var(--space-md);
    flex-shrink: 0;
  }

  :where(.dropdown-menu-radio-item) {
    position: relative;
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    border-radius: var(--radius-sm);
    padding-block: var(--space-xs);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    outline: none;
    cursor: default;
    user-select: none;
    inline-size: 100%;
    padding-inline-start: var(--space-lg);
    padding-inline-end: var(--space-sm);
  }

  :where(.dropdown-menu-radio-item)[data-disabled] {
    pointer-events: none;
    opacity: .5;
  }

  :where(.dropdown-menu-radio-item):focus {
    background-color: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dropdown-menu-radio-item)[data-highlighted] {
    background-color: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dropdown-menu-radio-item) svg {
    pointer-events: none;
    inline-size: var(--space-md);
    block-size: var(--space-md);
    flex-shrink: 0;
  }

  :where(.dropdown-menu-checkbox-indicator) {
    position: absolute;
    left: var(--space-sm);
    display: flex;
    inline-size: var(--text-ui);
    block-size: var(--text-ui);
    pointer-events: none;
    justify-content: center;
    align-items:  center;
  }

  :where(.dropdown-menu-radio-indicator) {
    position: absolute;
    left: var(--space-sm);
    display: flex;
    inline-size: var(--text-ui);
    block-size: var(--text-ui);
    pointer-events: none;
    justify-content: center;
    align-items:  center;
  }

  :where(.dropdown-menu-check-icon) {
    inline-size: var(--space-md);
    block-size: var(--space-md);
  }

  :where(.dropdown-menu-radio-indicator):after {
    content: "";
    background-color: var(--accent);
    opacity: 0;
    border-radius: 50%;
    block-size: 6px;
    inline-size: 6px;
  }

  [aria-checked="true"] > :where(.dropdown-menu-radio-indicator):after {
    opacity: 1;
  }

  :where(.dropdown-menu-label) {
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    font-weight: var(--weight-medium);
  }

  :where(.dropdown-menu-label)[data-inset="true"] {
    padding-inline-start: var(--space-lg);
  }

  :where(.dropdown-menu-separator) {
    margin-block: var(--space-xs);
    margin-inline: calc(var(--space-xs) * -1);
    background-color: var(--line);
    block-size: 1px;
  }

  :where(.dropdown-menu-shortcut) {
    font-size: var(--text-ui);
    line-height: var(--leading-snug);
    letter-spacing: .1em;
    color: var(--muted);
    margin-inline-start: auto;
  }

  :where(.dropdown-menu-sub-trigger) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    border-radius: var(--radius-sm);
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    outline: none;
    cursor: default;
    user-select: none;
    inline-size: 100%;
  }

  :where(.dropdown-menu-sub-trigger)[data-inset="true"] {
    padding-inline-start: var(--space-lg);
  }

  :where(.dropdown-menu-sub-trigger):focus {
    background-color: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dropdown-menu-sub-trigger)[data-highlighted] {
    background-color: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dropdown-menu-sub-trigger)[data-state="open"] {
    background-color: var(--surface-alt);
    color: var(--ink);
  }

  :where(.dropdown-menu-sub-trigger) svg:not([class*="text-"]) {
    color: var(--muted);
    pointer-events: none;
    inline-size: var(--space-md);
    block-size: var(--space-md);
    flex-shrink: 0;
  }

  :where(.dropdown-menu-sub-trigger-icon) {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    margin-inline-start: auto;
  }

  [data-slot="dropdown-menu-sub"] {
    position: relative;
  }

  :where(.dropdown-menu-sub-content) {
    z-index: var(--z-popover);
    overflow: hidden;
    animation: dropdown-menu-in var(--duration) var(--ease) both;
  }

  :where(.dropdown-menu-sub-content)[data-state="closing"] {
    animation: dropdown-menu-out var(--duration) var(--ease) both;
  }

  :where(.dropdown-menu-drawer-content) {
    padding-block-end: max(var(--space-sm), env(safe-area-inset-bottom));
  }

  :where(.dropdown-menu-step-viewport) {
    overflow: hidden;
    inline-size: 100%;
  }

  :where(.dropdown-menu-step-track) {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 100%;
    transform: translateX(calc(var(--step-depth, 0) * -100%));
    transition: transform var(--duration) var(--ease);
    inline-size: 100%;
  }

  :where(.dropdown-menu-step-panel) {
    display: flex;
    flex-direction: column;
    align-self:  start;
    min-inline-size: 0;
  }

  :where(.dropdown-menu-step-back) {
    display: inline-flex;
    align-self:  flex-start;
    align-items:  center;
    gap: var(--space-2xs);
    margin-block: var(--space-2xs);
    margin-inline: var(--space-2xs);
    padding-block: var(--space-xs);
    padding-inline: var(--space-xs) var(--space-sm);
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    color: var(--ink);
    border-radius: var(--radius-sm);
    cursor: pointer;
    outline: none;
    background: none;
    border: none;
  }

  :where(.dropdown-menu-step-back):focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: var(--space-3xs);
  }

  :where(.dropdown-menu-step-back) svg {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    color: var(--muted);
  }

  :where(.dropdown-menu-step-back-label) {
    color: var(--ink-muted);
  }

  :where(.dropdown-menu-content)[data-surface="drawer"] {
    box-shadow: none;
    padding: var(--space-xs) var(--space-sm) var(--space-sm);
    animation: none;
    background-color: #0000;
    border: none;
    border-radius: 0;
    max-block-size: none;
    inline-size: 100%;
    min-inline-size: 0;
  }

  :where(.dropdown-menu-content)[data-surface="drawer"][data-state="closing"] {
    animation: none;
  }

  :where(.dropdown-menu-content)[data-surface="drawer"] :where(.dropdown-menu-item) {
    padding-block: var(--space-sm);
    padding-inline: var(--space-sm);
    font-size: var(--text-base);
  }

  :where(.dropdown-menu-content)[data-surface="drawer"] :where(.dropdown-menu-checkbox-item) {
    padding-block: var(--space-sm);
    padding-inline: var(--space-sm);
    font-size: var(--text-base);
  }

  :where(.dropdown-menu-content)[data-surface="drawer"] :where(.dropdown-menu-radio-item) {
    padding-block: var(--space-sm);
    padding-inline: var(--space-sm);
    font-size: var(--text-base);
  }

  :where(.dropdown-menu-content)[data-surface="drawer"] :where(.dropdown-menu-sub-trigger) {
    padding-block: var(--space-sm);
    padding-inline: var(--space-sm);
    font-size: var(--text-base);
  }

  :where(.dropdown-menu-content)[data-surface="drawer"] :where(.dropdown-menu-checkbox-item) {
    padding-inline-start: var(--space-xl);
  }

  :where(.dropdown-menu-content)[data-surface="drawer"] :where(.dropdown-menu-radio-item) {
    padding-inline-start: var(--space-xl);
  }

  :where(.dropdown-menu-content)[data-surface="drawer"] :where(.dropdown-menu-label) {
    padding-block: var(--space-sm);
    padding-inline: var(--space-sm);
    font-size: var(--text-ui);
    color: var(--muted);
  }
}

/* packages/ui/src/styles/blocks/app-launcher.css */
@layer components {
  :where(.app-launcher-trigger) {
    flex-shrink: 0;
  }

  :where(.app-topbar) {
    position: sticky;
    z-index: calc(var(--z-raised)  + 1);
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    block-size: var(--space-lg);
    padding-inline: var(--space-xs);
    pointer-events: none;
    padding-block-end: var(--space-xs);
    top: var(--alert-banner-offset, var(--space-sm));
  }

  :where(.app-topbar) > * {
    pointer-events: auto;
    display: flex;
    align-items:  center;
  }

  :where(.app-topbar-start) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
  }

  :where(.app-topbar-middle) {
    display: flex;
    pointer-events: auto;
    mask-image: linear-gradient(to right, transparent, black var(--space-lg), black calc(100% - var(--space-lg)), transparent);
    flex: 1;
    align-items:  center;
    min-inline-size: 0;
    margin-inline-start: calc(-1 * var(--space-lg));
    padding-inline-start: var(--space-lg);
  }

  :where(.app-topbar-middle) > .scroll-area {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    overflow-y: hidden;
  }

  :where(.app-topbar-middle) .breadcrumb-list {
    container-type: normal;
    padding: var(--space-xs) var(--space-sm);
    word-break: normal;
    white-space: nowrap;
    flex-wrap: nowrap;
    inline-size: -moz-fit-content;
    inline-size: fit-content;
  }

  :where(.app-topbar-middle) .breadcrumb-link {
    color: var(--muted);
  }

  :where(.app-topbar-middle) .breadcrumb-link:hover {
    color: var(--ink);
  }

  :where(.app-topbar-middle) [data-slot="breadcrumb-separator"] {
    color: var(--muted);
  }

  :where(.app-topbar-middle) [data-slot="breadcrumb-current"] {
    color: var(--accent);
  }

  :where(.app-topbar-search) {
    color: var(--muted);
  }

  :where(.app-topbar-search-icon) {
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.app-topbar-end) {
    display: flex;
    flex-shrink: 0;
    align-items:  center;
    margin-inline-start: auto;
  }

  :where(.app-topbar-end) .dropdown-menu {
    align-self:  center;
  }

  :where(.app-topbar-end-surface) {
    display: flex;
    align-items:  center;
    gap: var(--space-2xs);
    padding: var(--space-2xs);
    --surface-bg: var(--sidebar-card-bg);
    --surface-shadow: var(--sidebar-card-shadow);
    --surface-radius: var(--sidebar-radius);
  }

  :where(.app-topbar-end-surface) .nav-user-compact-trigger {
    margin-inline-start: 0;
  }

  :where(.app-topbar-brand) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    text-decoration: none;
    color: var(--ink);
    font-weight: var(--weight-medium);
    border-radius: var(--radius-sm);
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    transition: background-color var(--duration) var(--ease);
  }

  :where(.app-topbar-brand):hover {
    background: color-mix(in oklab, var(--ink) 6%, transparent);
  }

  :where(.app-topbar):before {
    content: "";
    position: absolute;
    background: var(--app-bg-gradient), var(--app-bg-base);
    z-index: -1;
    opacity: 0;
    animation: content-breadcrumb-line-reveal linear both;
    animation-timeline: scroll();
    animation-range: 0 var(--space-xl);
    background-attachment: fixed;
    top: -5rem;
    bottom: 0;
    left: -100vw;
    right: -100vw;
  }

  :where(.app-topbar):after {
    content: "";
    position: absolute;
    block-size: var(--space-2xs);
    background: linear-gradient(to right, var(--paper) 25%, color-mix(in oklab, var(--paper) 25%, transparent) 75%);
    box-shadow: 0 var(--space-sm) var(--space-sm) 0 var(--app-bg-base, var(--paper));
    opacity: 0;
    animation: content-breadcrumb-line-reveal linear both;
    animation-timeline: scroll();
    animation-range: calc(var(--space-xl) * 2) calc(var(--space-xl) * 4);
    bottom: 0;
    left: -100vw;
    right: -100vw;
  }

  @media (min-width: 48rem) {
    :where(.app-topbar) {
      padding-inline-end: calc(var(--app-topbar-end-reserve, clamp(10rem, 14vw, 12rem))  + var(--space-sm));
    }

    :where(.app-topbar-end) {
      min-inline-size: var(--app-topbar-end-reserve, clamp(10rem, 14vw, 12rem));
      justify-content: flex-end;
    }

    :where(.app-topbar-end-surface) {
      position: fixed;
      right: calc(var(--sidebar-offset)  + var(--safe-area-right));
      top: calc(var(--sidebar-offset)  + var(--safe-area-top));
      z-index: calc(var(--z-raised)  + 2);
    }

    .app-layout[data-state="expanded"][data-mobile="false"] :where(.app-topbar):before {
      display: none;
    }

    .app-layout[data-state="expanded"][data-mobile="false"] :where(.app-topbar):after {
      display: none;
    }
  }

  @media (max-width: 47.9375rem) {
    :where(.app-topbar-end-surface) {
      box-shadow: none;
      background: none;
      padding: 0;
    }

    :where(.app-topbar-end[data-has-mobile-menu="true"]) :where(.app-topbar-end-surface) {
      display: none;
    }
  }

  :where(.app-topbar-mobile-menu) {
    display: none;
  }

  @media (max-width: 47.9375rem) {
    :where(.app-topbar-mobile-menu) {
      display: flex;
      align-items:  center;
    }

    :where(.app-topbar) {
      block-size: var(--space-xl);
      align-items:  center;
    }

    :where(.app-topbar-brand) {
      gap: var(--space-sm);
    }

    :where(.app-topbar) :where(.app-mobile-header-logo) {
      block-size: 1.75rem;
      inline-size: 1.75rem;
    }

    :where(.app-topbar) :where(.app-mobile-header-name) {
      font-size: var(--text-base);
    }

    :where(.app-topbar) :where(.sidebar-toggle) {
      --button-font-size: var(--text-base);
    }

    :where(.app-topbar) :where(.sidebar-toggle-icon) {
      block-size: 1.75rem;
      inline-size: 1.75rem;
    }

    :where(.app-topbar-mobile-avatar) {
      block-size: 2.25rem;
      inline-size: 2.25rem;
    }
  }

  :where(.app-topbar-mobile-trigger) {
    position: relative;
    display: inline-flex;
    padding: var(--space-2xs);
    border-radius: var(--radius-full);
    cursor: pointer;
    background: none;
    border: 0;
    justify-content: center;
    align-items:  center;
  }

  :where(.app-topbar-mobile-trigger):focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
  }

  :where(.app-topbar-mobile-avatar) {
    block-size: 2rem;
    inline-size: 2rem;
  }

  :where(.app-topbar-mobile-badge) {
    position: absolute;
    border-radius: var(--radius-full);
    background: var(--accent);
    color: var(--paper);
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    text-align: center;
    box-shadow: 0 0 0 2px var(--app-bg-base, var(--paper));
    block-size: 1rem;
    min-inline-size: 1rem;
    padding-inline-start: .25rem;
    padding-inline-end: .25rem;
    line-height: 1rem;
    top: 0;
    right: 0;
  }

  :where(.app-topbar-mobile-row-count) {
    border-radius: var(--radius-full);
    background: var(--accent);
    color: var(--paper);
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    text-align: center;
    min-inline-size: 1.25rem;
    margin-inline-start: auto;
    padding-inline-start: .4rem;
    padding-inline-end: .4rem;
    line-height: 1.25rem;
  }

  :where(.app-topbar-mobile-app-dot) {
    --tile-color: var(--accent);
    display: inline-flex;
    border-radius: var(--radius-sm);
    background: linear-gradient(to bottom, var(--tile-color), color-mix(in oklab, var(--tile-color) 70%, black 30%));
    color: var(--paper);
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
    block-size: 1.5rem;
    inline-size: 1.5rem;
  }

  :where(.app-topbar-mobile-row-avatar) {
    block-size: 1.5rem;
    inline-size: 1.5rem;
  }

  :where(.app-launcher-grid) {
    display: grid;
    grid-template-columns: repeat(3, 5.5rem);
    gap: var(--space-xs);
    padding: var(--space-xs);
  }

  :where(.app-launcher-grid) .app-launcher-list {
    display: contents;
    list-style: none;
    margin: 0;
    padding: 0;
  }

  :where(.app-launcher-grid) .app-launcher-item {
    display: contents;
  }

  :where(.app-launcher-grid) .app-launcher-item > .tooltip-root {
    display: contents;
  }

  :where(.dropdown-menu-content)[data-surface="drawer"] :where(.app-launcher-grid) {
    grid-template-columns: repeat(3, 1fr);
  }

  @container dialog (inline-size >= 24rem) {
    :where(.dropdown-menu-content)[data-surface="drawer"] :where(.app-launcher-grid) {
      grid-template-columns: repeat(4, 1fr);
    }
  }

  :where(.app-launcher-tile) {
    --tile-color: var(--accent);
    position: relative;
    display: flex;
    border-radius: var(--radius-lg);
    text-decoration: none;
    cursor: pointer;
    background: linear-gradient(to bottom, var(--tile-color), color-mix(in oklab, var(--tile-color) 70%, black 30%));
    transition: filter var(--duration) var(--ease);
    aspect-ratio: 1;
    overflow: hidden;
    justify-content: center;
    align-items:  center;
  }

  :where(.app-launcher-tile):hover {
    filter: brightness(1.06);
  }

  :where(.app-launcher-tile):focus-visible {
    outline: var(--space-2xs) solid var(--accent);
    outline-offset: var(--space-2xs);
  }

  :where(.dropdown-menu-content):has(.app-launcher-grid) {
    --surface-radius: var(--radius-xl);
  }

  :where(.app-launcher-avatar) {
    font-size: var(--text-3xl);
    font-weight: var(--weight-semibold);
    user-select: none;
    line-height: 1;
    translate: 0 -10%;
  }

  :where(.app-launcher-label) {
    position: absolute;
    font-size: var(--text-caption);
    line-height: var(--leading-snug);
    text-align: center;
    padding-inline: var(--space-sm);
    padding-block: var(--space-2xs);
    bottom: 0;
    left: 0;
    right: 0;
  }
}

.app-launcher-tile, .app-launcher-tile:visited {
  color: var(--paper);
}

/* packages/ui/src/styles/blocks/notification-bell.css */
@layer components {
  :where(.notification-bell-trigger) {
    position: relative;
  }

  :where(.notification-bell-badge) {
    position: absolute;
    border-radius: var(--radius-full);
    background: var(--accent);
    color: var(--paper);
    font-size: .5rem;
    font-weight: var(--weight-bold);
    text-align: center;
    pointer-events: none;
    letter-spacing: -.01em;
    block-size: .75rem;
    min-inline-size: .75rem;
    padding-inline-start: .2rem;
    padding-inline-end: .2rem;
    line-height: .75rem;
    top: .1rem;
    right: .1rem;
  }

  :where(.notification-bulk-actions) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.notification-delete-all) {
    color: var(--danger);
    border-color: var(--danger);
  }

  :where(.notification-delete-all):hover {
    background-color: color-mix(in oklab, var(--danger) 8%, transparent);
  }

  :where(.notification-delete-all-confirm) {
    background-color: var(--danger);
    color: var(--paper);
  }

  :where(.notification-delete-all-confirm):hover {
    background-color: color-mix(in oklab, var(--danger) 85%, oklch(0 0 0));
  }

  :where(.notification-panel-body) {
    padding: 0;
  }

  :where(.notification-panel-scroll) {
    flex: 1;
    min-block-size: 0;
  }

  :where(.notification-alerts-section) {
    border-block-end: 1px solid color-mix(in oklab, var(--line) 40%, transparent);
    padding-block-end: var(--space-sm);
  }

  :where(.notification-alerts-label) {
    padding-inline: var(--space-lg);
    padding-block: var(--space-sm) var(--space-xs);
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--muted);
  }

  :where(.notification-alerts-list) {
    padding-inline: var(--space-md);
    padding-block-end: var(--space-xs);
  }

  :where(.notification-alert-item) {
    --alert-color: var(--accent);
  }

  :where(.notification-alert-item[data-tone="warning"]) {
    --alert-color: var(--warning);
  }

  :where(.notification-alert-item[data-tone="danger"]) {
    --alert-color: var(--danger);
  }

  :where(.notification-alert-item[data-tone="positive"]) {
    --alert-color: var(--positive);
  }

  :where(.notification-alert-item) .item {
    border-inline-start: 2px solid color-mix(in oklab, var(--alert-color) 60%, transparent);
  }

  :where(.notification-alert-item-row) {
    display: flex;
    align-items:  flex-start;
    gap: var(--space-sm);
  }

  :where(.notification-alert-icon) {
    display: flex;
    color: var(--alert-color);
    opacity: .8;
    flex-shrink: 0;
    padding-block-start: .1em;
  }

  :where(.notification-alert-body) {
    flex: 1;
    min-inline-size: 0;
  }

  :where(.notification-list) {
    padding: var(--space-md) var(--space-lg);
  }

  :where(.notification-item) {
    position: relative;
    cursor: default;
    background: var(--surface);
  }

  :where(.notification-item)[data-interactive] {
    cursor: pointer;
  }

  :where(.notification-item)[data-unread] {
    cursor: pointer;
    background-color: color-mix(in oklab, var(--accent) 4%, transparent);
  }

  :where(.notification-item)[data-unread]:hover {
    background-color: color-mix(in oklab, var(--accent) 8%, transparent);
  }

  :where(.notification-unread-dot) {
    display: block;
    border-radius: var(--radius-full);
    background: var(--accent);
    block-size: .4rem;
    inline-size: .4rem;
  }

  :where(.notification-item-primary-action) {
    display: flex;
    cursor: pointer;
    text-align: start;
    color: inherit;
    font: inherit;
    background: none;
    border: none;
    flex: 1;
    align-items:  center;
    min-inline-size: 0;
    margin: 0;
    padding: 0;
  }

  :where(.notification-item-title-row) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.notification-item-title-row) :where(.item-title) {
    flex: 1;
    inline-size: auto;
    min-inline-size: 0;
  }

  :where(.notification-item-meta) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    flex-shrink: 0;
  }

  :where(.notification-detail-time) {
    font-size: var(--text-caption);
    color: var(--muted);
    line-height: var(--leading-normal);
  }

  :where(.notification-item-time) {
    font-size: var(--text-caption);
    color: var(--muted);
    line-height: var(--leading-normal);
  }

  :where(.notification-detail-body) {
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    color: var(--ink);
    white-space: pre-wrap;
  }

  :where(.notification-load-more) {
    display: flex;
    padding-block: var(--space-xs);
    justify-content: center;
  }
}

/* packages/ui/src/styles/blocks/split-button.css */
@layer components {
  :where(.split-button) {
    font-size: var(--split-button-font-size, var(--text-ui));
    --split-button-bg: var(--accent);
    --split-button-fg: var(--paper);
    --split-button-border: transparent;
    --split-button-divider: color-mix(in oklab, var(--paper) 30%, transparent);
    position: relative;
    display: inline-flex;
    align-items: stretch;
  }

  .split-button[data-variant="outline"] {
    --split-button-bg: transparent;
    --split-button-fg: var(--ink);
    --split-button-border: var(--line);
    --split-button-divider: var(--line);
  }

  .split-button[data-size="sm"] {
    font-size: var(--text-caption);
  }

  .split-button[data-size="lg"] {
    font-size: var(--text-base);
  }

  .split-button-action, .split-button-trigger {
    display: inline-flex;
    box-sizing: border-box;
    background: var(--split-button-bg);
    color: var(--split-button-fg);
    border: 1px solid var(--split-button-border);
    font-size: inherit;
    font-weight: var(--weight-medium);
    white-space: nowrap;
    cursor: pointer;
    user-select: none;
    transition: all var(--duration) var(--ease);
    justify-content: center;
    align-items:  center;
    block-size: 2.618em;
    line-height: 1;
  }

  :is(.split-button-action, .split-button-trigger):hover:not(:disabled) {
    filter: brightness(.95);
  }

  :is(.split-button-action, .split-button-trigger):disabled {
    opacity: .5;
    cursor: not-allowed;
  }

  :is(.split-button-action, .split-button-trigger):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
    z-index: 1;
  }

  .split-button-action {
    border-inline-end: none;
    border-radius: .382em 0 0 .382em;
    gap: .382em;
    padding-inline-start: .809em;
    padding-inline-end: .809em;
  }

  .split-button-action[data-loading] {
    position: relative;
    color: #0000;
    pointer-events: none;
  }

  .split-button-action[data-loading]:after {
    content: "";
    color: var(--split-button-fg);
    position: absolute;
    border: 2px solid;
    animation: button-spin .6s linear infinite;
    border-right-color: #0000;
    border-radius: 50%;
    block-size: 1.272em;
    inline-size: 1.272em;
    margin: auto;
    inset: 0;
  }

  .split-button-divider {
    background: var(--split-button-divider);
    align-self: stretch;
    inline-size: 1px;
  }

  .split-button-trigger {
    border-inline-start: none;
    border-radius: 0 .382em .382em 0;
    padding-inline-start: .382em;
    padding-inline-end: .382em;
  }

  .split-button-chevron {
    transition: transform var(--duration) var(--ease);
    block-size: 1em;
    inline-size: 1em;
  }

  .split-button-trigger[data-open] .split-button-chevron {
    transform: rotate(180deg);
  }

  .split-button[data-variant="outline"] .split-button-action:hover:not(:disabled), .split-button[data-variant="outline"] .split-button-trigger:hover:not(:disabled) {
    background: color-mix(in oklab, var(--accent) 12%, var(--paper));
    border-color: color-mix(in oklab, var(--accent) 40%, var(--line));
    filter: none;
  }

  .split-button[data-variant="outline"] .split-button-action:hover:not(:disabled) {
    border-inline-end: none;
  }

  .split-button[data-variant="outline"] .split-button-trigger:hover:not(:disabled) {
    border-inline-start: none;
  }

  .split-button-menu {
    min-inline-size: 10rem;
  }
}

/* packages/ui/src/styles/blocks/picker.css */
@keyframes picker-in {
  from {
    opacity: 0;
    transform: scale(.95) translateY(calc(var(--space-sm) * -1));
  }

  to {
    opacity: 1;
    transform: scale(1)translateY(0);
  }
}

@keyframes picker-out {
  from {
    opacity: 1;
    transform: scale(1)translateY(0);
  }

  to {
    opacity: 0;
    transform: scale(.95) translateY(calc(var(--space-sm) * -1));
  }
}

@layer components {
  ::view-transition-old(.picker-content) {
    animation: picker-out var(--duration) var(--ease);
    transform-origin: var(--transform-origin);
    animation-fill-mode: both;
  }

  ::view-transition-new(.picker-content) {
    animation: picker-in var(--duration) var(--ease);
    transform-origin: var(--transform-origin);
    animation-fill-mode: both;
  }

  :where(.picker) {
    position: relative;
    display: inline-flex;
  }

  :where(.picker-trigger) {
    display: inline-flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--picker-trigger-gap, var(--space-sm));
    min-inline-size: var(--picker-trigger-min-inline-size, 10rem);
    cursor: pointer;
    user-select: none;
  }

  :where(.picker-trigger) .picker-trigger-icon {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    color: var(--muted);
    transition: transform var(--duration) var(--ease);
    flex-shrink: 0;
  }

  :where(.picker-trigger-control) {
    min-inline-size: var(--picker-trigger-min-inline-size, 10rem);
    min-block-size: var(--picker-trigger-size, var(--input-size, var(--control-md)));
    padding-inline: var(--picker-trigger-px, var(--input-px, var(--space-sm)));
    padding-block: var(--picker-trigger-py, var(--input-py, var(--space-xs)));
    background: var(--picker-trigger-bg, var(--input-bg, var(--paper)));
    color: var(--picker-trigger-fg, var(--input-fg, var(--ink)));
    border: 1px solid var(--picker-trigger-border, var(--input-border, var(--line)));
    border-radius: var(--picker-trigger-radius, var(--input-radius, var(--radius-md)));
    font-size: var(--picker-trigger-font-size, var(--input-font-size, var(--text-ui)));
    line-height: var(--leading-normal);
    transition: border-color var(--duration) var(--ease), box-shadow var(--duration) var(--ease), background var(--duration) var(--ease);
  }

  :where(.picker-trigger-control):hover:not([aria-disabled]):not(:disabled) {
    border-color: var(--picker-trigger-border-hover, var(--input-border-hover, var(--accent)));
  }

  :where(.picker-trigger-control):focus-visible {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--focus-ring);
  }

  :where(.picker-trigger-control)[aria-invalid="true"] {
    border-color: var(--danger);
  }

  :where(.picker-trigger-control)[aria-invalid="true"]:focus-visible {
    box-shadow: 0 0 0 3px var(--focus-ring-danger);
  }

  :where(.picker-trigger-control)[aria-disabled] {
    opacity: .5;
    cursor: not-allowed;
    background: var(--surface);
  }

  :where(.picker-trigger-control):disabled {
    opacity: .5;
    cursor: not-allowed;
    background: var(--surface);
  }

  :where(.picker[data-open]) .picker-trigger-icon {
    transform: rotate(180deg);
  }

  :where(.picker-value) {
    text-align: start;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
  }

  :where(.picker-value[data-placeholder]) {
    color: var(--picker-trigger-placeholder-color, var(--muted));
  }

  :where(.picker-positioner) {
    z-index: var(--z-popover);
    position: absolute;
    inset: 0;
  }

  :where(.picker-content) {
    --surface-radius: var(--radius-md);
    max-block-size: var(--available-height, 20rem);
    overflow-y: auto;
    background-color: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--surface-radius);
    box-shadow: var(--surface-shadow);
    color: var(--ink);
    padding: var(--space-xs);
    min-inline-size: 10rem;
  }

  :where(.picker-search) {
    position: sticky;
    z-index: 1;
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    padding: var(--space-xs);
    background: var(--surface);
    margin-block-end: var(--space-xs);
    padding-block-start: var(--space-sm);
    top: calc(-1 * var(--space-xs));
  }

  :where(.picker-search-icon) {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    color: var(--muted);
    flex-shrink: 0;
  }

  :where(.picker-search-input) {
    padding-inline: var(--space-sm);
    padding-block: var(--space-xs);
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    font-size: var(--text-ui);
    flex: 1;
  }

  :where(.picker-search-input):focus {
    outline: none;
    border-color: var(--line-strong, var(--line));
    box-shadow: 0 0 0 1px var(--line);
  }

  :where(.picker-search-input)::placeholder {
    color: var(--muted);
  }

  :where(.picker-option) {
    position: relative;
    display: grid;
    grid-template-columns: var(--space-md) 1fr;
    gap: var(--space-sm);
    border-radius: var(--radius-sm);
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    outline: none;
    cursor: default;
    user-select: none;
    text-align: start;
    color: inherit;
    background: none;
    border: none;
    align-items:  center;
    inline-size: 100%;
  }

  :where(.picker-option)[data-disabled] {
    pointer-events: none;
    opacity: .5;
  }

  :where(.picker-option):hover {
    background-color: var(--surface-alt);
  }

  :where(.picker-option)[data-highlighted] {
    background-color: var(--surface-alt);
  }

  :where(.picker-option):focus {
    outline: none;
  }

  :where(.picker-option):focus-visible {
    background-color: var(--surface-alt);
    outline: 2px solid var(--accent);
    outline-offset: -2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.picker-option)[data-selected] {
    font-weight: var(--weight-medium);
  }

  :where(.picker-option) svg:not(.picker-option-indicator svg) {
    color: var(--muted);
    pointer-events: none;
    inline-size: var(--space-md);
    block-size: var(--space-md);
    flex-shrink: 0;
  }

  :where(.picker-option-indicator) {
    display: flex;
    inline-size: var(--space-md);
    block-size: var(--space-md);
    justify-content: center;
    align-items:  center;
  }

  :where(.picker-option-indicator) svg {
    inline-size: var(--space-md);
    block-size: var(--space-md);
  }

  :where(.picker-group) + .picker-group {
    margin-block-start: var(--space-xs);
  }

  :where(.picker-group-label) {
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--muted);
  }

  :where(.picker-separator) {
    margin-block: var(--space-xs);
    margin-inline: calc(var(--space-xs) * -1);
    background-color: var(--line);
    block-size: 1px;
  }

  :where(.picker-empty) {
    padding: var(--space-md);
    text-align: center;
    color: var(--muted);
    font-size: var(--text-ui);
  }

  :where(.picker-sheet-content) {
    padding-block-end: max(var(--space-sm), env(safe-area-inset-bottom));
  }

  :where(.picker-sheet-body) {
    display: flex;
    overflow: hidden;
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
  }

  :where(.picker-content-sheet) {
    box-shadow: none;
    padding: 0 var(--space-sm);
    overflow-y: auto;
    overscroll-behavior: contain;
    background-color: #0000;
    border: none;
    border-radius: 0;
    flex: 1;
    min-block-size: 0;
    max-block-size: none;
    inline-size: 100%;
  }

  :where(.picker-content-sheet) :where(.picker-option) {
    padding-block: var(--space-sm);
    padding-inline: var(--space-sm);
    font-size: var(--text-base);
  }

  :where(.picker-content-sheet) :where(.picker-search) {
    padding-block: var(--space-sm);
    background-color: var(--surface);
    margin-block-start: 0;
    top: 0;
  }

  :where(.picker-content-sheet) :where(.picker-search-input) {
    padding-block: var(--space-sm);
    font-size: var(--text-base);
  }
}

/* packages/ui/src/styles/blocks/combobox.css */
@layer components {
  :where(.combobox) {
    position: relative;
  }

  :where(.combobox-listbox) {
    position: absolute;
    z-index: var(--z-popover);
    overflow-y: auto;
    list-style: none;
    padding: var(--space-3xs);
    background-color: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    box-shadow: var(--surface-shadow);
    max-block-size: 12rem;
    margin-block-start: var(--space-3xs);
    top: 100%;
    left: 0;
    right: 0;
  }

  :where(.combobox-option) {
    padding: var(--space-2xs) var(--space-xs);
    border-radius: var(--radius-sm);
    color: var(--ink);
    font-size: var(--text-ui);
    cursor: pointer;
  }

  :where(.combobox-option:hover) {
    background: var(--surface-alt);
  }

  :where(.combobox-option[data-active]) {
    background: var(--surface-alt);
  }
}

/* packages/ui/src/styles/blocks/tag-input.css */
@layer components {
  .tag-input {
    position: relative;
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    min-block-size: var(--input-size, 2.5rem);
    padding-inline: var(--input-px, var(--space-sm));
    padding-block: var(--space-xs);
    background: var(--input-bg, var(--paper));
    border: 1px solid var(--input-border, var(--line));
    border-radius: var(--input-radius, var(--radius-md));
    cursor: text;
    transition: border-color var(--duration) var(--ease);
    flex-wrap: wrap;
  }

  .tag-input:hover:not([data-disabled]) {
    border-color: var(--input-border-hover, var(--accent));
  }

  .tag-input:focus-within {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--focus-ring);
  }

  .tag-input[data-disabled] {
    opacity: .5;
    cursor: not-allowed;
    background: var(--surface);
  }

  .tag-input-tag {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-xs);
    background: var(--surface);
    border-radius: var(--radius-full);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    color: var(--ink);
    white-space: nowrap;
    padding-block-start: 2px;
    padding-block-end: 2px;
    padding-inline-start: var(--space-sm);
    padding-inline-end: var(--space-xs);
  }

  .tag-input-remove {
    display: inline-flex;
    border-radius: var(--radius-full);
    color: var(--muted);
    cursor: pointer;
    transition: background-color var(--duration) var(--ease), color var(--duration) var(--ease);
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
    padding: 2px;
  }

  .tag-input-remove:hover {
    background: color-mix(in oklab, var(--ink) 10%, transparent);
    color: var(--ink);
  }

  .tag-input-remove:focus {
    outline: none;
    background: color-mix(in oklab, var(--ink) 10%, transparent);
  }

  .tag-input-input {
    outline: none;
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    color: var(--ink);
    background: none;
    border: none;
    flex: 8ch;
    min-inline-size: 8ch;
    padding: 0;
  }

  .tag-input-input::placeholder {
    color: var(--muted);
  }

  .tag-input-input:disabled {
    cursor: not-allowed;
  }

  .tag-input-suggestions {
    position: absolute;
    z-index: var(--z-popover);
    padding: var(--space-xs);
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    list-style: none;
    overflow-y: auto;
    max-block-size: 12rem;
    margin-block-start: var(--space-xs);
    top: 100%;
    left: 0;
    right: 0;
  }

  .tag-input-suggestions li {
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-sm);
    font-size: var(--text-ui);
    cursor: pointer;
    transition: background-color var(--duration) var(--ease);
  }

  .tag-input-suggestions li:hover {
    background: var(--surface);
  }

  .tag-input-suggestions li[data-focused] {
    background: var(--surface);
  }
}

/* packages/ui/src/styles/blocks/composer.css */
@layer components {
  :where(.composer) {
    position: relative;
    display: flex;
    background: var(--input-bg, var(--paper));
    border: 1px solid var(--input-border, var(--line));
    border-radius: var(--input-radius, var(--radius-md));
    transition: border-color var(--duration) var(--ease);
    flex-direction: column;
    gap: 0;
  }

  :where(.composer):hover:where(:not([data-disabled])) {
    border-color: var(--input-border-hover, var(--accent));
  }

  :where(.composer):focus-within {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--focus-ring);
  }

  :where(.composer)[data-disabled] {
    opacity: .5;
    cursor: not-allowed;
    background: var(--surface);
  }

  :where(.composer)[data-size="sm"] {
    --composer-font-size: var(--text-caption);
    --composer-padding: var(--space-xs);
  }

  :where(.composer)[data-size="lg"] {
    --composer-font-size: var(--text-base);
    --composer-padding: var(--space-md);
  }

  :where(.composer-toolbar) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    padding: var(--composer-padding, var(--space-sm));
    border-block-end: 1px solid var(--line-subtle, color-mix(in oklab, var(--line) 50%, transparent));
  }

  :where(.composer-input) {
    display: block;
    padding: var(--composer-padding, var(--space-sm));
    outline: none;
    resize: none;
    font-family: inherit;
    font-size: var(--composer-font-size, var(--text-ui));
    line-height: var(--leading-normal);
    color: var(--input-fg, var(--ink));
    field-sizing: content;
    min-block-size: calc(var(--composer-min-rows, 1) * var(--leading-normal) * 1em + var(--composer-padding, var(--space-sm)) * 2);
    max-block-size: calc(var(--composer-max-rows, 8) * var(--leading-normal) * 1em + var(--composer-padding, var(--space-sm)) * 2);
    background: none;
    border: none;
    inline-size: 100%;
  }

  :where(.composer-input)::placeholder {
    color: var(--muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  :where(.composer-input):disabled {
    cursor: not-allowed;
  }

  :where(.composer-footer) {
    display: flex;
    justify-content: flex-end;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--composer-padding, var(--space-sm));
    padding-block-start: 0;
  }

  :where(.composer-counter) {
    display: flex;
    align-items:  center;
    gap: var(--space-2xs);
    color: var(--muted);
    font-variant-numeric: tabular-nums;
    opacity: 0;
    transition: opacity var(--duration) var(--ease);
    margin-inline-end: auto;
  }

  :where(.composer-counter)[data-has-content] {
    opacity: 1;
  }

  :where(.composer-counter)[data-warn] {
    color: var(--warning);
  }

  :where(.composer-counter)[data-over] {
    color: var(--danger);
  }

  :where(.composer):focus-within :where(.composer-counter) {
    opacity: 1;
  }

  :where(.composer-counter-arc) {
    flex-shrink: 0;
  }

  :where(.composer-counter-track) {
    stroke: currentColor;
    opacity: .2;
  }

  :where(.composer-counter-progress) {
    stroke: currentColor;
    transition: stroke-dashoffset var(--duration) var(--ease);
  }

  :where(.composer-counter-label) {
    font-size: var(--text-caption);
    font-weight: var(--weight-medium);
  }

  :where(.composer-submit) {
    margin-inline-start: auto;
  }

  :where(.composer-submit)[data-loading] {
    pointer-events: none;
  }

  :where(.composer-submit-spinner) {
    block-size: 1em;
    inline-size: 1em;
  }
}

/* packages/ui/src/styles/blocks/nav-main.css */
@layer components {
  :where(.nav-main-row) {
    display: flex;
    border-radius: var(--radius-sm);
    transition: background-color .15s var(--ease), color .15s var(--ease);
    align-items:  center;
    gap: 0;
  }

  .nav-main-row:hover:not(:has([data-active="true"])) {
    background-color: color-mix(in oklab, var(--surface) 90%, var(--ink));
  }

  .nav-main-row:has([data-active="true"]) {
    background-color: color-mix(in oklab, var(--surface) 90%, var(--accent));
  }

  .nav-main-row:has([data-active="true"]) .nav-main-link {
    color: var(--accent);
  }

  .nav-main-row:has([data-active="true"]) .nav-main-chevron-button {
    color: var(--accent);
  }

  :where(.nav-main-link) {
    text-decoration: none;
    flex: 1;
    min-inline-size: 0;
  }

  .nav-main-row .nav-main-link {
    --button-bg: transparent;
    --button-bg-hover: transparent;
    background: none;
    flex: 1;
    inline-size: auto;
  }

  .nav-main-row .nav-main-link:hover {
    background: none;
  }

  .nav-main-row .nav-main-link:hover:not([data-active="true"]) {
    background: none;
  }

  .nav-main-row .nav-main-link[data-active="true"] {
    background: none;
  }

  :where(.sidebar-menu-button.nav-main-link) > svg {
    block-size: 1rem;
    inline-size: 1rem;
  }

  .nav-main-chevron {
    transition: transform var(--duration) var(--ease);
    flex-shrink: 0;
    block-size: 1.125rem;
    inline-size: 1.125rem;
  }

  .collapsible-trigger[data-state="open"] .nav-main-chevron {
    transform: rotate(90deg);
  }

  .nav-main-link > .nav-main-chevron {
    block-size: 1.125rem;
    inline-size: 1.125rem;
    margin-inline-start: auto;
  }

  .collapsible[data-state="open"] .nav-main-link > .nav-main-chevron {
    transform: rotate(90deg);
  }

  .collapsible-trigger.nav-main-chevron-button {
    display: flex;
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    border-radius: var(--radius-sm);
    color: color-mix(in oklab, var(--ink) 50%, transparent);
    background: none;
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
  }

  .nav-main-chevron-button:focus-visible {
    box-shadow: 0 0 0 2px var(--accent);
    outline: none;
  }

  .collapsible:has(.nav-main-row) .sidebar-submenu {
    border-inline-start: none;
    padding-block-start: var(--space-md);
    padding-block-end: 0;
  }

  :where(.nav-main-subroot-header) {
    margin-block-end: var(--space-sm);
  }

  .nav-main-subroot-back > svg:first-child {
    flex-shrink: 0;
    block-size: 1.125rem;
    inline-size: 1.125rem;
  }

  :where(.nav-main-subroot-title) {
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 0;
    min-inline-size: 0;
  }

  :where(.nav-main-subroot-parent) {
    font-size: var(--text-caption);
    color: color-mix(in oklab, currentColor 55%, transparent);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
  }

  .nav-main-menu .sidebar-menu-button, .nav-main-menu .sidebar-menu-button[data-size], .nav-main-subroot-header .sidebar-menu-button, .nav-main-subroot-header .sidebar-menu-button[data-size], .nav-main-menu .sidebar-submenu-button, .nav-main-menu .sidebar-submenu-button[data-size] {
    font-size: var(--text-ui);
    padding-block: var(--space-xs);
    block-size: auto;
  }

  :where(.nav-main-menu) {
    opacity: 0;
    transition: opacity .15s ease-out;
  }

  .nav-main-menu[data-ready] {
    opacity: 1;
  }

  .nav-main-menu[data-animate="enter"] {
    animation: nav-main-slide-in .2s ease-out;
  }

  .nav-main-menu[data-animate="exit"] {
    animation: nav-main-slide-out .2s ease-out;
  }

  @keyframes nav-main-slide-in {
    from {
      opacity: 0;
      transform: translateX(var(--space-lg));
    }

    to {
      opacity: 1;
      transform: translateX(0);
    }
  }

  @keyframes nav-main-slide-out {
    from {
      opacity: 0;
      transform: translateX(calc(-1 * var(--space-lg)));
    }

    to {
      opacity: 1;
      transform: translateX(0);
    }
  }

  .nav-main-link[data-completed]:not([data-active="true"]), .sidebar-submenu-button[data-completed]:not([data-active="true"]) {
    color: color-mix(in oklab, var(--ink) 55%, var(--accent));
  }

  .nav-main-complete-icon {
    color: var(--accent);
    opacity: .7;
    flex-shrink: 0;
    margin-inline-start: auto;
  }

  .nav-main-menu svg.nav-main-complete-icon {
    block-size: .8125rem;
    inline-size: .8125rem;
  }

  :where(.nav-main-indicator) {
    display: inline-flex;
    color: var(--accent);
    opacity: .7;
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
    margin-inline-start: auto;
  }

  :where(.nav-main-indicator) > svg {
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.nav-main-empty) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding-block: var(--space-xl);
    padding-inline: var(--space-md);
    color: color-mix(in oklab, var(--ink) 35%, transparent);
    text-align: center;
    flex-direction: column;
  }

  :where(.nav-main-empty) > svg {
    opacity: .6;
    block-size: 1.5rem;
    inline-size: 1.5rem;
  }

  :where(.nav-main-empty) > span {
    font-size: var(--text-ui);
  }
}

/* packages/ui/src/styles/blocks/nav-user.css */
@layer components {
  :where(.nav-user-row) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-xs);
    inline-size: 100%;
  }

  :where(.nav-user-avatar) {
    flex-shrink: 0;
  }

  :where(.nav-user-trigger-name) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-align: start;
    font-size: var(--text-ui);
    font-weight: var(--weight-normal);
    color: var(--muted);
    flex: 1;
  }

  :where(.nav-user-menu-trigger) {
    color: var(--muted);
    flex-shrink: 0;
  }

  :where(.nav-user-menu-trigger):hover {
    color: var(--ink);
  }

  :where(.nav-user-info) {
    display: grid;
    text-align: start;
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    flex: 1;
  }

  :where(.nav-user-name) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: var(--weight-medium);
  }

  :where(.nav-user-email) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: var(--text-ui);
    line-height: var(--leading-snug);
  }

  :where(.nav-user-chevron) {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    margin-inline-start: auto;
  }

  :where(.nav-user-menu-label) {
    font-weight: var(--weight-normal);
    padding: 0;
  }

  :where(.nav-user-menu-label-content) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding-inline: var(--space-xs);
    padding-block: var(--space-xs);
    text-align: start;
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
  }

  :where(.nav-user-avatar-fallback) {
    border-radius: var(--radius-md);
  }

  :where(.nav-user-dropdown-content) {
    inline-size: var(--radix-dropdown-menu-trigger-width);
    border-radius: var(--radius-md);
    min-inline-size: 14rem;
  }

  :where(.nav-user-signin-cta) {
    flex: 1;
  }

  :where(.nav-user-theme-icon) {
    flex-shrink: 0;
  }

  :where(.nav-user-theme-check) {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    margin-inline-start: auto;
  }

  :where(.nav-user-row[data-loading]) {
    background: color-mix(in oklab, var(--surface) 50%, transparent);
    border-radius: var(--radius-sm);
    animation: nav-user-pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;
    min-block-size: 2.5rem;
  }

  @keyframes nav-user-pulse {
    0%, 100% {
      opacity: 1;
    }

    50% {
      opacity: .5;
    }
  }

  :where(.nav-user-compact-trigger) {
    display: flex;
    inline-size: var(--control-md);
    block-size: var(--control-md);
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: opacity var(--duration) var(--ease);
    color: var(--muted);
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
    margin-inline-start: var(--space-xs);
    padding: 0;
  }

  :where(.nav-user-compact-trigger):hover {
    opacity: .8;
  }

  :where(.nav-user-compact-trigger):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.nav-user-compact-avatar) {
    --avatar-size: 1.25rem;
    font-size: .5rem;
  }

  :where(.nav-user-compact-skeleton) {
    border-radius: var(--radius-full);
    block-size: 1.25rem;
    inline-size: 1.25rem;
  }

  :where(.nav-user-compact-guest) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
  }

  :where(.nav-user-compact-signin) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
  }

  :where(.nav-user-subscribe) {
    color: var(--accent);
  }

  :where(.nav-user-subscribe) svg {
    color: var(--accent);
  }

  :where(.ios-install-steps) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
    margin: 0;
    padding-inline-start: var(--space-lg);
  }

  :where(.ios-install-steps) li {
    display: flex;
    flex-wrap: wrap;
    align-items:  center;
    gap: .25em;
    line-height: 1.5;
  }

  :where(.ios-install-step-icon) {
    vertical-align: -.15em;
    color: var(--accent);
    block-size: 1em;
    inline-size: 1em;
  }

  :where(.nav-user-toggle-count) {
    padding-inline: var(--space-xs);
    font-size: var(--text-caption);
    font-weight: var(--weight-medium);
    color: var(--muted);
    background: var(--surface-alt);
    border-radius: var(--radius-full);
    text-align: center;
    min-inline-size: 1.25rem;
    margin-inline-start: auto;
  }
}

/* packages/ui/src/styles/blocks/page-actions.css */
@layer components {
  [data-slot="page-actions-trigger"] {
    --button-font-size: var(--text-caption);
    color: var(--muted);
    align-self:  flex-start;
  }

  [data-slot="page-actions-trigger"]:hover {
    color: var(--ink);
  }

  [data-slot="page-actions-trigger"] svg {
    inline-size: var(--space-md);
    block-size: var(--space-md);
  }

  [data-slot="page-actions-menu"] {
    white-space: nowrap;
  }

  [data-slot="page-actions-menu"] [data-slot="dropdown-menu-item"] svg {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    flex-shrink: 0;
  }

  .page-actions-sub-value {
    padding-inline: var(--space-xs);
    font-size: var(--text-caption);
    color: var(--muted);
    margin-inline-start: auto;
  }
}

/* packages/ui/src/styles/blocks/sidebar.css */
.drawer-backdrop:has( + [data-slot="drawer-content"].sidebar-sheet) {
  background-color: color-mix(in oklab, var(--paper) 70%, transparent);
}

::view-transition-old(sidebar-sheet) {
  animation: sidebar-sheet-out .22s ease both;
}

::view-transition-new(sidebar-sheet) {
  animation: sidebar-sheet-in .22s ease both;
}

@keyframes sidebar-sheet-in {
  from {
    opacity: 0;
    transform: translateX(-100%);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes sidebar-sheet-out {
  from {
    opacity: 1;
    transform: translateX(0);
  }

  to {
    opacity: 0;
    transform: translateX(-100%);
  }
}

@property --app-bg-gradient-opacity {
  syntax: "<number>";
  inherits: true;
  initial-value: 1;
}

@layer components {
  @keyframes app-bg-gradient-fade {
    from {
      --app-bg-gradient-opacity: 1;
    }

    to {
      --app-bg-gradient-opacity: 0;
    }
  }

  :root {
    --sidebar-width: 20rem;
    --sidebar-radius: var(--radius-md);
  }

  @keyframes sidebar-fade-in {
    from {
      opacity: 0;
    }

    to {
      opacity: 1;
    }
  }

  @keyframes sidebar-fade-out {
    from {
      opacity: 1;
    }

    to {
      opacity: 0;
    }
  }

  :where(.app-layout) {
    --sidebar-offset: clamp(var(--space-xs), 1.5vw, 1.25rem);
    --sidebar-radius: clamp(var(--space-sm), 2vw, 1.25rem);
    --sidebar-card-bg: color-mix(in oklab, var(--surface) 78%, transparent);
    --sidebar-card-shadow: var(--shadow-card);
    --sidebar-container-padding: clamp(var(--space-xs), 1vw, var(--space-sm));
    --sidebar-container-padding-collapsed: clamp(var(--space-xs), .9vw, var(--space-sm));
    --sidebar-inner-padding: clamp(var(--space-xs), 1.2vw, var(--space-sm));
    --sidebar-inner-gap: clamp(var(--space-xs), 1.2vw, var(--space-sm));
    --sidebar-inner-radius-offset: clamp(var(--space-xs), .8vw, var(--space-sm));
    --sidebar-inner-padding-collapsed: clamp(var(--space-xs), .8vw, var(--space-sm));
    --sidebar-inner-gap-collapsed: clamp(var(--space-xs), .8vw, var(--space-sm));
    --sidebar-inner-bg: transparent;
    --sidebar-inner-shadow: none;
    display: flex;
    container-type: inline-size;
    container-name: sidebar;
    align-items: stretch;
    gap: clamp(var(--space-sm), 3vw, var(--space-md));
    overscroll-behavior: none;
    overflow-x: clip;
    --app-bg-gradient: radial-gradient(70% 50% at 55% -5%, oklch(from var(--accent) .75 calc(c * .3) calc(h + 35) / calc(.06 * var(--app-bg-gradient-opacity, 1))) 35%, transparent 100%);
    --app-bg-base: color-mix(in oklab, var(--paper) 96%, transparent);
    background: var(--app-bg-gradient), var(--app-bg-base);
    animation: app-bg-gradient-fade linear both;
    animation-timeline: scroll();
    animation-range: 0 20rem;
    background-attachment: fixed;
    flex-direction: column;
    min-block-size: 100svh;
    inline-size: 100%;
    padding-block-start: calc(var(--sidebar-offset)  + var(--safe-area-top));
    padding-block-end: calc(var(--sidebar-offset)  + var(--safe-area-bottom));
    padding-inline-start: calc(var(--sidebar-offset)  + var(--safe-area-left));
    padding-inline-end: calc(var(--sidebar-offset)  + var(--safe-area-right));
    transition: gap .22s, padding-block-start .22s, padding-block-end .22s, padding-inline-start .22s, padding-inline-end .22s;
  }

  :where(.sidebar-sr-only) {
    position: absolute;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
    block-size: 1px;
    inline-size: 1px;
    margin: -1px;
    padding: 0;
  }

  .app-layout[data-mobile="true"] {
    gap: 0;
  }

  .app-layout:has(.sidebar[data-variant="floating"]) {
    padding-block-start: calc(clamp(var(--space-sm), 1.2vw, var(--space-xs))  + var(--safe-area-top));
    padding-block-end: calc(clamp(var(--space-sm), 1.2vw, var(--space-xs))  + var(--safe-area-bottom));
    padding-inline-start: calc(clamp(var(--space-sm), 1.2vw, var(--space-xs))  + var(--safe-area-left));
    padding-inline-end: calc(clamp(var(--space-sm), 1.2vw, var(--space-xs))  + var(--safe-area-right));
  }

  .app-layout:has(.sidebar[data-variant="inset"]) {
    --app-bg-base: color-mix(in oklab, var(--paper) 98%, transparent);
  }

  @media (min-width: 48rem) {
    .app-layout {
      flex-direction: row;
      align-items: stretch;
    }

    .app-layout[data-state="collapsed"][data-mobile="false"] {
      gap: clamp(var(--space-xs), 1.5vw, var(--space-sm));
    }
  }

  @media (max-width: 47.9375rem) {
    .app-layout {
      flex-direction: column;
      gap: 0;
    }
  }

  @media (prefers-reduced-motion: reduce) {
    .app-layout {
      transition: none;
    }

    :where(.sidebar-container) {
      transition: none;
    }
  }

  :where(.sidebar) {
    color: var(--ink);
    display: none;
    position: relative;
    z-index: var(--z-raised);
    min-inline-size: 0;
  }

  @media (min-width: 48rem) {
    .sidebar {
      display: flex;
      flex: 0 0 min(var(--sidebar-width), 100%);
      max-inline-size: min(var(--sidebar-width), 100%);
      transition: flex-basis .22s, max-inline-size .22s;
    }

    .app-layout[data-state="collapsed"][data-mobile="false"] .sidebar[data-collapsible="offcanvas"] {
      flex-basis: 0;
      max-inline-size: 0;
    }

    .app-layout[data-state="collapsed"][data-mobile="false"] .sidebar[data-collapsible="icon"] {
      flex-basis: var(--sidebar-width-icon, calc(3rem + var(--space-sm)));
      max-inline-size: var(--sidebar-width-icon, calc(3rem + var(--space-sm)));
    }
  }

  :where(.sidebar-gap) {
    display: none;
  }

  :where(.sidebar-container) {
    position: sticky;
    display: flex;
    inline-size: min(var(--sidebar-width), 100%);
    block-size: calc(100svh - (var(--sidebar-offset) * 2)  - var(--safe-area-top)  - var(--safe-area-bottom));
    padding: var(--sidebar-container-padding);
    --surface-bg: var(--sidebar-card-bg);
    --surface-shadow: var(--sidebar-card-shadow);
    --surface-radius: var(--sidebar-radius);
    z-index: 5;
    opacity: 1;
    will-change: transform, opacity, width;
    transition: transform .22s, opacity .18s, inline-size .22s;
    top: calc(var(--sidebar-offset)  + var(--safe-area-top));
    transform: translate3d(0, 0, 0);
  }

  .sidebar[data-side="right"] .sidebar-container {
    margin-inline-start: auto;
  }

  .sidebar[data-state="collapsed"][data-collapsible="offcanvas"] .sidebar-container {
    opacity: 0;
    transform: translateX(calc((-1) * (var(--sidebar-width)  + var(--sidebar-offset))));
    pointer-events: none;
  }

  .sidebar[data-side="right"][data-state="collapsed"][data-collapsible="offcanvas"] .sidebar-container {
    transform: translateX(calc(var(--sidebar-width)  + var(--sidebar-offset)));
  }

  .sidebar[data-state="collapsed"][data-collapsible="icon"] .sidebar-container {
    inline-size: var(--sidebar-width-icon, calc(3rem + var(--space-sm)));
    padding: var(--sidebar-container-padding-collapsed);
  }

  .sidebar[data-state="expanded"] .sidebar-container {
    opacity: 1;
    pointer-events: auto;
    transform: translate3d(0, 0, 0);
  }

  .sidebar[data-variant="floating"] .sidebar-container {
    --surface-bg: color-mix(in oklab, var(--surface) 72%, transparent);
  }

  :where(.sidebar-inner) {
    display: flex;
    gap: var(--sidebar-inner-gap);
    border-radius: calc(var(--sidebar-radius)  - var(--sidebar-inner-radius-offset));
    background: var(--sidebar-inner-bg);
    box-shadow: var(--sidebar-inner-shadow);
    overflow: visible;
    flex-direction: column;
    flex: 1;
    block-size: 100%;
    inline-size: 100%;
  }

  .sidebar[data-state="collapsed"][data-collapsible="icon"] .sidebar-inner {
    padding: var(--sidebar-inner-padding-collapsed);
    gap: var(--sidebar-inner-gap-collapsed);
    border-radius: calc(var(--sidebar-radius)  - clamp(var(--radius-sm), .6vw, var(--radius-md)));
  }

  :where(.sidebar-trigger) {
    inline-size: calc(var(--space-lg)  - var(--space-xs));
    block-size: calc(var(--space-lg)  - var(--space-xs));
  }

  :where(.sidebar-toggle) {
    --button-font-size: var(--text-caption);
    border-radius: var(--radius-sm);
    transition: background-color var(--duration) ease, opacity var(--duration) ease;
    flex-shrink: 0;
  }

  :where(.sidebar-toggle-icon) {
    inline-size: calc(var(--space-md)  + var(--space-xs));
    block-size: calc(var(--space-md)  + var(--space-xs));
  }

  :where(.sidebar-toggle-edge) {
    transition: opacity var(--duration) var(--ease);
  }

  :where(.sidebar-toggle-panel) {
    transform-origin: inline-start center;
    transition: opacity var(--duration) ease, transform var(--duration) ease;
  }

  .sidebar-toggle-icon:not([data-expanded="true"]) .sidebar-toggle-edge {
    opacity: 1;
  }

  .sidebar-toggle-icon:not([data-expanded="true"]) .sidebar-toggle-panel {
    opacity: 0;
    transform: scaleX(0);
  }

  .sidebar-toggle-icon[data-expanded="true"] .sidebar-toggle-edge {
    opacity: 0;
  }

  .sidebar-toggle-icon[data-expanded="true"] .sidebar-toggle-panel {
    opacity: 1;
    transform: scaleX(1);
  }

  .sidebar-brand-toggle {
    margin-inline-end: var(--space-xs);
  }

  :where(.app-main) {
    position: relative;
    display: flex;
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
    inline-size: 100%;
    min-inline-size: 0;
  }

  :where(.app-mobile-header-logo) {
    display: flex;
    color: var(--accent);
    justify-content: center;
    align-items:  center;
    block-size: 1.25rem;
    inline-size: 1.25rem;
  }

  .app-mobile-header-logo > svg, .app-mobile-header-logo > img {
    object-fit: contain;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.app-mobile-header-name) {
    font-size: var(--text-ui);
    white-space: nowrap;
  }

  :where(.sidebar-input) {
    background-color: var(--paper);
    box-shadow: none;
    block-size: 2rem;
    inline-size: 100%;
  }

  :where(.sidebar-header) {
    display: flex;
    gap: var(--space-sm);
    padding: var(--sidebar-section-padding, var(--space-sm));
    flex-direction: column;
  }

  :where(.sidebar-brand) {
    position: relative;
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
  }

  :where(.sidebar-brand-link) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-sm);
    border-radius: var(--radius-sm);
    text-decoration: none;
    color: inherit;
    transition: background-color var(--duration) var(--ease);
    flex: 1;
    min-inline-size: 0;
  }

  .sidebar-brand-link:hover {
    background-color: color-mix(in oklab, var(--ink) 6%, transparent);
  }

  :where(.sidebar-brand-logo) {
    display: flex;
    aspect-ratio: 1;
    color: var(--accent);
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
    block-size: 2rem;
    inline-size: 2rem;
  }

  .sidebar-brand-logo > svg, .sidebar-brand-logo > img {
    object-fit: contain;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.sidebar-brand-info) {
    display: grid;
    text-align: left;
    line-height: var(--leading-snug);
    flex: 1;
    min-inline-size: 0;
  }

  :where(.sidebar-brand-title) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: var(--text-lg);
    font-weight: var(--weight-medium);
    letter-spacing: .01em;
  }

  :where(.sidebar-brand-subtitle) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: var(--text-ui);
    color: color-mix(in oklab, var(--ink) 70%, transparent);
  }

  :where(.sidebar-footer) {
    display: flex;
    gap: var(--space-sm);
    padding: var(--sidebar-section-padding, var(--space-sm));
    flex-direction: column;
  }

  :where(.sidebar-separator) {
    background-color: var(--line);
    margin-inline: var(--space-sm);
    inline-size: auto;
  }

  :where(.sidebar-rule) {
    --_rule-bleed: var(--sidebar-section-padding, var(--space-sm));
    background-color: color-mix(in oklab, var(--line) 50%, transparent);
    border: none;
    block-size: 1px;
    inline-size: 100%;
    margin: 0;
  }

  :where(.sidebar-rule)[data-bleed="true"] {
    margin-inline: calc(-3 * var(--_rule-bleed));
    inline-size: calc(100% + (var(--_rule-bleed) * 6));
  }

  :where(.sidebar-content) {
    display: flex;
    gap: clamp(var(--space-sm), .8vw, var(--space-xs));
    overflow: auto;
    scrollbar-width: thin;
    scrollbar-color: color-mix(in oklab, var(--line) 65%, transparent) color-mix(in oklab, var(--surface) 85%, transparent);
    mask-image: linear-gradient(180deg, transparent 0, #000 clamp(var(--space-sm), 1.2vw, var(--space-sm)), #000 calc(100% - clamp(var(--space-xs), 1.6vw, 1.25rem)), transparent 100%);
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
    padding-inline-end: var(--space-xs);
  }

  .sidebar-content::-webkit-scrollbar {
    inline-size: 6px;
  }

  .sidebar-content::-webkit-scrollbar-thumb {
    background: color-mix(in oklab, var(--line) 70%, transparent);
    border-radius: var(--radius-full);
  }

  .sidebar-content::-webkit-scrollbar-track {
    background: none;
  }

  .sidebar[data-collapsible="icon"] .sidebar-content {
    overflow: hidden;
  }

  :where(.sidebar-group) {
    position: relative;
    display: flex;
    padding: var(--space-sm);
    flex-direction: column;
    inline-size: 100%;
    min-inline-size: 0;
  }

  :where(.sidebar-group-label) {
    color: color-mix(in oklab, var(--ink) 70%, transparent);
    display: flex;
    border-radius: var(--radius-sm);
    padding-inline: var(--space-sm);
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    line-height: var(--leading-snug);
    outline: none;
    transition: margin .2s ease-linear, opacity .2s ease-linear;
    flex-shrink: 0;
    align-items:  center;
    block-size: 2rem;
  }

  .sidebar-group-label:focus-visible {
    box-shadow: 0 0 0 2px var(--accent);
  }

  .sidebar-group-label > svg {
    inline-size: var(--space-sm);
    block-size: var(--space-sm);
    flex-shrink: 0;
  }

  .sidebar[data-collapsible="icon"] .sidebar-group-label {
    opacity: 0;
    margin-block-start: -2rem;
  }

  .sidebar-group-action {
    color: var(--ink);
    position: absolute;
    top: calc(var(--space-sm)  - 2px);
    right: var(--space-xs);
    display: flex;
    border-radius: var(--radius-sm);
    outline: none;
    justify-content: center;
    align-items:  center;
    block-size: 1.25rem;
    inline-size: 1.25rem;
    padding: 0;
    transition: transform;
  }

  .sidebar-group-action:hover {
    background-color: color-mix(in oklab, var(--accent) 12%, var(--paper));
    color: var(--ink);
  }

  .sidebar-group-action:focus-visible {
    box-shadow: 0 0 0 2px var(--accent);
  }

  .sidebar-group-action > svg {
    inline-size: var(--space-sm);
    block-size: var(--space-sm);
    flex-shrink: 0;
  }

  .sidebar-group-action:after {
    content: "";
    position: absolute;
    inset: calc(var(--space-sm) * -1);
  }

  @container sidebar (width >= 48rem) {
    .sidebar-group-action:after {
      display: none;
    }
  }

  .sidebar[data-collapsible="icon"] .sidebar-group-action {
    display: none;
  }

  :where(.sidebar-group-content) {
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    inline-size: 100%;
  }

  :where(.sidebar-menu) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
    inline-size: 100%;
    min-inline-size: 0;
  }

  :where(.sidebar-menu-item) {
    position: relative;
    list-style: none;
  }

  :where(.sidebar-menu-button) {
    display: flex;
    justify-content: flex-start;
    align-items:  center;
    gap: var(--space-sm);
    border-radius: var(--radius-sm);
    padding: var(--space-sm);
    text-align: left;
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    white-space: normal;
    outline: none;
    text-decoration: none;
    --button-bg: transparent;
    --button-bg-hover: transparent;
    inline-size: 100%;
  }

  .sidebar-menu-button[data-active="true"] {
    --button-bg: color-mix(in oklab, var(--surface) 90%, var(--accent));
    --button-fg: var(--accent);
    --button-bg-hover: color-mix(in oklab, var(--surface) 90%, var(--accent));
    font-weight: var(--weight-medium);
  }

  .sidebar-menu-button:focus-visible {
    box-shadow: 0 0 0 2px var(--accent);
  }

  .sidebar-menu-button:disabled, .sidebar-menu-button[aria-disabled="true"] {
    pointer-events: none;
    opacity: .5;
  }

  .sidebar-menu-item:has([data-sidebar="menu-action"]) .sidebar-menu-button {
    padding-inline-end: var(--space-lg);
  }

  .sidebar[data-collapsible="icon"] .sidebar-menu-button {
    padding: var(--space-sm) !important;
    block-size: 2rem !important;
    inline-size: 2rem !important;
  }

  .sidebar-menu-button > svg {
    inline-size: var(--space-sm);
    block-size: var(--space-sm);
    flex-shrink: 0;
  }

  .sidebar-menu-button[data-size="sm"] {
    block-size: calc(2rem - var(--space-xs));
    font-size: var(--text-ui);
    line-height: var(--leading-snug);
  }

  .sidebar-menu-button[data-size="lg"] {
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    block-size: 3rem;
  }

  .sidebar[data-collapsible="icon"] .sidebar-menu-button[data-size="lg"] {
    padding: 0 !important;
  }

  .sidebar-menu-button[data-variant="outline"] {
    background-color: var(--paper);
    box-shadow: 0 0 0 1px var(--line);
  }

  .sidebar-menu-button[data-variant="outline"]:hover {
    background-color: color-mix(in oklab, var(--accent) 12%, var(--paper));
    color: var(--ink);
    box-shadow: 0 0 0 1px var(--accent);
  }

  .sidebar-menu-action {
    color: var(--ink);
    position: absolute;
    top: calc(var(--space-sm)  - 2px);
    right: var(--space-xs);
    display: flex;
    border-radius: var(--radius-sm);
    outline: none;
    justify-content: center;
    align-items:  center;
    block-size: 1.25rem;
    inline-size: 1.25rem;
    padding: 0;
    transition: transform;
  }

  .sidebar-menu-action:hover {
    background-color: color-mix(in oklab, var(--accent) 12%, var(--paper));
    color: var(--ink);
  }

  .sidebar-menu-button:hover ~ .sidebar-menu-action {
    color: var(--ink);
  }

  .sidebar-menu-action:focus-visible {
    box-shadow: 0 0 0 2px var(--accent);
  }

  .sidebar-menu-action > svg {
    inline-size: var(--space-sm);
    block-size: var(--space-sm);
    flex-shrink: 0;
  }

  .sidebar-menu-action:after {
    content: "";
    position: absolute;
    inset: calc(var(--space-sm) * -1);
  }

  @container sidebar (width >= 48rem) {
    .sidebar-menu-action:after {
      display: none;
    }
  }

  .sidebar[data-collapsible="icon"] .sidebar-menu-action {
    display: none;
  }

  .sidebar-menu-action[data-show-on-hover="true"] {
    opacity: 0;
  }

  .sidebar-menu-item:focus-within .sidebar-menu-action[data-show-on-hover="true"], .sidebar-menu-item:hover .sidebar-menu-action[data-show-on-hover="true"], .sidebar-menu-action[data-show-on-hover="true"][data-state="open"] {
    opacity: 1;
  }

  .sidebar-menu-button[data-active="true"] ~ .sidebar-menu-action[data-show-on-hover="true"] {
    color: var(--ink);
  }

  @container sidebar (width >= 48rem) {
    .sidebar-menu-action[data-show-on-hover="true"] {
      opacity: 0;
    }

    .sidebar-menu-item:focus-within .sidebar-menu-action[data-show-on-hover="true"], .sidebar-menu-item:hover .sidebar-menu-action[data-show-on-hover="true"], .sidebar-menu-action[data-show-on-hover="true"][data-state="open"] {
      opacity: 1;
    }
  }

  .sidebar-menu-badge {
    color: var(--ink);
    pointer-events: none;
    position: absolute;
    right: var(--space-xs);
    display: flex;
    border-radius: var(--radius-sm);
    padding-inline: var(--space-xs);
    font-size: var(--text-ui);
    line-height: var(--leading-snug);
    font-weight: var(--weight-medium);
    user-select: none;
    font-feature-settings: "tnum";
    justify-content: center;
    align-items:  center;
    block-size: 1.25rem;
    min-inline-size: 1.25rem;
  }

  .sidebar-menu-button:hover ~ .sidebar-menu-badge, .sidebar-menu-button[data-active="true"] ~ .sidebar-menu-badge {
    color: var(--ink);
  }

  .sidebar-menu-badge[data-size="sm"] {
    top: var(--space-xs);
  }

  .sidebar-menu-badge[data-size="default"] {
    top: calc(var(--space-sm)  - 2px);
  }

  .sidebar-menu-badge[data-size="lg"] {
    top: var(--space-sm);
  }

  .sidebar[data-collapsible="icon"] .sidebar-menu-badge {
    display: none;
  }

  :where(.sidebar-menu-skeleton) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    border-radius: var(--radius-sm);
    padding-inline: var(--space-sm);
    block-size: 2rem;
  }

  .sidebar-submenu {
    border-inline-start: 1px solid color-mix(in oklab, var(--line) 40%, transparent);
    display: flex;
    gap: var(--space-xs);
    padding-inline-start: var(--space-xs);
    padding-block: var(--space-xs);
    flex-direction: column;
    min-inline-size: 0;
    margin-inline-start: var(--space-xs);
    translate: 1px;
  }

  .sidebar-submenu[data-level="2"], .sidebar-submenu[data-level="3"], .sidebar-submenu[data-level="4"] {
    margin-inline-start: var(--space-sm);
  }

  .sidebar[data-collapsible="icon"] .sidebar-submenu {
    display: none;
  }

  :where(.sidebar-submenu-item) {
    position: relative;
    list-style: none;
  }

  .sidebar-submenu-button {
    color: var(--ink);
    display: flex;
    text-align: start;
    min-block-size: calc(2rem - var(--space-xs));
    justify-content: flex-start;
    align-items:  center;
    gap: var(--space-sm);
    border-radius: var(--radius-sm);
    padding: var(--space-sm);
    white-space: normal;
    outline: none;
    text-decoration: none;
    min-inline-size: 0;
    transition: background-color .15s, color .15s;
  }

  .sidebar-submenu-button:hover:not([data-active="true"]) {
    background-color: color-mix(in oklab, var(--surface) 90%, var(--ink));
  }

  .sidebar-submenu-button[data-active="true"] {
    background-color: color-mix(in oklab, var(--surface) 90%, var(--accent));
    color: var(--accent);
  }

  .sidebar-submenu-button:focus-visible {
    box-shadow: 0 0 0 2px var(--accent);
  }

  .sidebar-submenu-button:disabled, .sidebar-submenu-button[aria-disabled="true"] {
    pointer-events: none;
    opacity: .5;
  }

  .sidebar-submenu-button > svg {
    inline-size: var(--space-sm);
    block-size: var(--space-sm);
    flex-shrink: 0;
  }

  .sidebar-submenu-button[data-size="sm"] {
    font-size: var(--text-ui);
    line-height: var(--leading-snug);
  }

  .sidebar-submenu-button[data-size="md"] {
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
  }

  .sidebar[data-collapsible="icon"] .sidebar-submenu-button {
    display: none;
  }

  .sidebar-sheet {
    --sidebar-mobile-inset: var(--space-sm);
    --sidebar-radius: clamp(var(--space-sm), 2vw, 1.25rem);
    color: var(--ink);
    inline-size: min(var(--sidebar-width), calc(100% - var(--sidebar-mobile-inset)));
    padding: var(--sidebar-container-padding, 0);
    --surface-bg: var(--sidebar-card-bg, color-mix(in oklab, var(--surface) 78%, transparent));
    --surface-shadow: var(--shadow-lg);
    view-transition-name: sidebar-sheet;
    touch-action: pan-y pinch-zoom;
    will-change: transform;
    top: 0 !important;
    bottom: 0 !important;
    left: var(--sidebar-mobile-inset) !important;
    border-radius: 0 var(--sidebar-radius) var(--sidebar-radius) 0 !important;
    border: none !important;
    block-size: 100svh !important;
  }

  .sidebar-sheet > button {
    display: none;
  }

  :where(.sidebar-sheet-inner) {
    display: flex;
    gap: var(--sidebar-inner-gap, clamp(var(--space-xs), 1.2vw, var(--space-sm)));
    --_pad: var(--sidebar-inner-padding, clamp(var(--space-xs), 1.2vw, var(--space-sm)));
    padding-block-start: calc(var(--_pad)  + var(--safe-area-top));
    padding-block-end: calc(var(--_pad)  + var(--safe-area-bottom));
    padding-inline: var(--_pad);
    flex-direction: column;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.sidebar-skeleton-icon) {
    inline-size: var(--space-sm);
    block-size: var(--space-sm);
    border-radius: var(--radius-sm);
  }

  :where(.sidebar-skeleton-text) {
    block-size: var(--space-sm);
    max-inline-size: var(--skeleton-width);
    flex: 1;
  }
}

/* packages/ui/src/styles/blocks/app-shell.css */
@layer components {
  :where(.app-shell-sidebar) {
    --card-radius: var(--radius-lg);
    --card-padding: clamp(var(--space-md), 1.4vw, var(--space-lg));
    --sidebar-card-bg: linear-gradient(165deg, color-mix(in oklab, var(--surface) 90%, transparent) 0%, var(--surface) 100%);
    --sidebar-card-backdrop: blur(1rem) saturate(1.35);
    --card-bg: var(--sidebar-card-bg);
    --card-backdrop: var(--sidebar-card-backdrop);
  }

  :where(.app-shell-sidebar-status) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-sm);
    background: color-mix(in oklab, var(--surface) 50%, transparent);
  }

  :where(.app-shell-content) {
    position: relative;
    display: flex;
    max-inline-size: var(--app-shell-content-max-inline-size, calc(90ch + var(--space-lg)  + 14rem));
    gap: var(--app-shell-content-gap, clamp(var(--space-md), 1.5vw, var(--space-lg)));
    padding-block-start: var(--app-shell-content-padding-block-start, clamp(var(--space-lg), 3vw, var(--space-xl)));
    padding-block-end: var(--app-shell-content-padding-block-end, clamp(var(--space-lg), 2vw, var(--space-xl)));
    padding-inline: var(--app-shell-content-padding-inline, clamp(var(--space-md), 2vw, var(--space-lg)));
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
    inline-size: 100%;
    margin-inline-start: auto;
    margin-inline-end: auto;
  }

  :where(.app-shell-content)[data-padding="none"] {
    --app-shell-content-gap: 0px;
    --app-shell-content-padding-block-start: 0px;
    --app-shell-content-padding-block-end: 0px;
    --app-shell-content-padding-inline: 0px;
  }

  :where(.app-shell-content)[data-padding="compact"] {
    --app-shell-content-gap: clamp(var(--space-sm), 1.25vw, var(--space-md));
    --app-shell-content-padding-block-start: var(--space-sm);
    --app-shell-content-padding-block-end: clamp(var(--space-md), 1.6vw, var(--space-lg));
    --app-shell-content-padding-inline: clamp(var(--space-sm), 1.6vw, var(--space-md));
  }

  :where(.app-shell-content):has(.absolute-layout) {
    overflow: hidden;
    --app-shell-content-gap: 0px;
    --app-shell-content-padding-block-end: 0px;
    flex: 1;
    min-block-size: 0;
  }

  :where(.app-layout):has(.app-shell-masked-viewport) {
    overflow: hidden;
    block-size: 100svh;
    max-block-size: 100svh;
  }

  :where(.app-shell-content):has( > .app-shell-masked-viewport) {
    overflow: hidden;
    --app-shell-content-gap: 0px;
    --app-shell-content-padding-block-start: 0px;
    --app-shell-content-padding-block-end: 0px;
    flex: 1;
    min-block-size: 0;
    padding-inline-start: 0;
    padding-inline-end: 0;
  }

  :where(.app-shell-masked-viewport) {
    position: relative;
    display: flex;
    timeline-scope: --page-scroll;
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
    inline-size: 100%;
  }

  :where(.app-shell-masked-scroller) {
    --masked-viewport-reserve-top: 0px;
    --masked-viewport-reserve-bottom: 0px;
    --masked-viewport-gap-top: 0px;
    --masked-viewport-gap-bottom: 0px;
    max-inline-size: var(--app-shell-content-max-inline-size, calc(90ch + var(--space-lg)  + 14rem));
    overflow-y: auto;
    overscroll-behavior: contain;
    scroll-padding-block-start: calc(var(--masked-viewport-reserve-top)  + var(--masked-viewport-gap-top));
    scroll-padding-block-end: calc(var(--masked-viewport-reserve-bottom)  + var(--masked-viewport-gap-bottom));
    scroll-timeline-name: --page-scroll;
    scroll-timeline-axis: block;
    display: flex;
    gap: var(--app-shell-content-gap, 0px);
    padding-block-start: calc(var(--app-shell-content-padding-block-start, 0px)  + var(--masked-viewport-reserve-top)  + var(--masked-viewport-gap-top));
    padding-block-end: calc(var(--app-shell-content-padding-block-end, 0px)  + var(--masked-viewport-reserve-bottom)  + var(--masked-viewport-gap-bottom));
    padding-inline: var(--app-shell-content-padding-inline, clamp(var(--space-md), 2vw, var(--space-lg)));
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
    inline-size: 100%;
    margin-inline-start: auto;
    margin-inline-end: auto;
  }

  :where(.app-shell-masked-viewport)[data-padding="none"] :where(.app-shell-masked-scroller) {
    --app-shell-content-gap: 0px;
    --app-shell-content-padding-block-start: 0px;
    --app-shell-content-padding-block-end: 0px;
    --app-shell-content-padding-inline: 0px;
  }

  :where(.app-shell-masked-viewport)[data-padding="compact"] :where(.app-shell-masked-scroller) {
    --app-shell-content-gap: clamp(var(--space-sm), 1.25vw, var(--space-md));
    --app-shell-content-padding-block-start: var(--space-sm);
    --app-shell-content-padding-block-end: clamp(var(--space-md), 1.6vw, var(--space-lg));
    --app-shell-content-padding-inline: clamp(var(--space-sm), 1.6vw, var(--space-md));
  }

  :where(.app-shell-masked-scroller)[data-mask="fade-y"] {
    --page-mask: linear-gradient(to bottom, transparent 0, transparent var(--masked-viewport-reserve-top), #000 calc(var(--masked-viewport-reserve-top)  + var(--masked-viewport-fade-top, 2rem)), #000 calc(100% - var(--masked-viewport-reserve-bottom)  - var(--masked-viewport-fade-bottom, 2rem)), transparent calc(100% - var(--masked-viewport-reserve-bottom)));
    -webkit-mask-image: var(--page-mask);
    mask-image: var(--page-mask);
  }

  :where(.app-shell-masked-scroller)[data-mask="fade-top"] {
    --page-mask: linear-gradient(to bottom, transparent 0, transparent var(--masked-viewport-reserve-top), #000 calc(var(--masked-viewport-reserve-top)  + var(--masked-viewport-fade-top, 2rem)));
    -webkit-mask-image: var(--page-mask);
    mask-image: var(--page-mask);
  }

  :where(.app-shell-masked-scroller)[data-mask="fade-bottom"] {
    --page-mask: linear-gradient(to bottom, #000 0, #000 calc(100% - var(--masked-viewport-reserve-bottom)  - var(--masked-viewport-fade-bottom, 2rem)), transparent calc(100% - var(--masked-viewport-reserve-bottom)));
    -webkit-mask-image: var(--page-mask);
    mask-image: var(--page-mask);
  }

  :where(.app-shell-masked-viewport-overlay) {
    position: absolute;
    pointer-events: none;
    z-index: 2;
    display: flex;
    justify-content: center;
    left: 0;
    right: 0;
  }

  :where(.app-shell-masked-viewport-overlay) > * {
    pointer-events: auto;
    max-inline-size: var(--app-shell-content-max-inline-size, calc(90ch + var(--space-lg)  + 14rem));
    padding-inline: var(--app-shell-content-padding-inline, clamp(var(--space-md), 2vw, var(--space-lg)));
    inline-size: 100%;
  }

  :where(.app-shell-masked-viewport-overlay)[data-placement="top"] {
    top: 0;
  }

  :where(.app-shell-masked-viewport-overlay)[data-placement="bottom"] {
    align-items:  flex-end;
    bottom: 0;
  }

  :where(.app-shell-masked-viewport):has( > .app-shell-masked-viewport-overlay[data-placement="top"]) > :where(.app-shell-masked-scroller) {
    --masked-viewport-reserve-top: var(--masked-viewport-reserve-top-override, 5rem);
    --masked-viewport-gap-top: var(--masked-viewport-gap-top-override, var(--space-lg));
  }

  :where(.app-shell-masked-viewport):has( > .app-shell-masked-viewport-overlay[data-placement="bottom"]) > :where(.app-shell-masked-scroller) {
    --masked-viewport-reserve-bottom: var(--masked-viewport-reserve-bottom-override, 7rem);
    --masked-viewport-gap-bottom: var(--masked-viewport-gap-bottom-override, var(--space-lg));
  }

  :where(.app-shell-nav-secondary) {
    border-block-start: 1px solid color-mix(in oklab, var(--line) 40%, transparent);
    margin-block-start: auto;
    padding-block-start: clamp(var(--space-sm), 1vw, var(--space-md));
  }
}

/* packages/ui/src/styles/blocks/app-loading.css */
@layer components {
  :where(.app-loading-overlay) {
    position: fixed;
    z-index: var(--z-max);
    display: grid;
    background: var(--surface);
    opacity: 1;
    place-items:  center;
    transition: opacity .3s ease-out;
    inset: 0;
  }

  :where(.app-loading-overlay)[data-fading] {
    opacity: 0;
    pointer-events: none;
  }

  :where(.app-loading-overlay-icon) {
    block-size: 2.5rem;
    inline-size: 2.5rem;
  }

  :where(.app-loading-stuck) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
    text-align: center;
    padding: var(--space-lg);
    flex-direction: column;
    max-inline-size: 24rem;
  }

  :where(.app-loading-stuck-title) {
    font-size: var(--text-lg);
    font-weight: var(--weight-semibold);
    color: var(--ink);
  }

  :where(.app-loading-stuck-body) {
    font-size: var(--text-ui);
    color: var(--muted);
    line-height: 1.5;
  }

  :where(.app-loading-stuck-retry) {
    padding-block: var(--space-sm);
    padding-inline: var(--space-lg);
    border-radius: var(--radius-md);
    background: var(--accent);
    color: var(--paper);
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    cursor: pointer;
    border: none;
    transition: opacity .15s;
  }

  :where(.app-loading-stuck-retry:hover) {
    opacity: .9;
  }
}

/* packages/ui/src/styles/blocks/markdown.css */
@layer components {
  :where(.Markdown) {
    --prose-max-width: 90ch;
    max-inline-size: var(--prose-max-width);
    color: var(--ink);
    font-family: var(--font-content);
    font-size: var(--text-base);
    line-height: var(--leading-normal);
  }

  :where(.Markdown :-webkit-any(h1, h2, h3, h4, h5, h6)) {
    line-height: var(--leading-snug);
    font-weight: var(--weight-semibold);
    letter-spacing: -.02em;
    margin-block-start: 1.5em;
    margin-block-end: .5em;
    scroll-margin-block-start: var(--space-lg);
  }

  :where(.Markdown :-moz-any(h1, h2, h3, h4, h5, h6)) {
    line-height: var(--leading-snug);
    font-weight: var(--weight-semibold);
    letter-spacing: -.02em;
    margin-block-start: 1.5em;
    margin-block-end: .5em;
    scroll-margin-block-start: var(--space-lg);
  }

  :where(.Markdown :is(h1, h2, h3, h4, h5, h6)) {
    line-height: var(--leading-snug);
    font-weight: var(--weight-semibold);
    letter-spacing: -.02em;
    margin-block-start: 1.5em;
    margin-block-end: .5em;
    scroll-margin-block-start: var(--space-lg);
  }

  :where(.Markdown h1) {
    font-size: var(--text-4xl);
    margin-block-start: 0;
  }

  :where(.Markdown h2) {
    font-size: var(--text-xl);
  }

  :where(.Markdown h3) {
    font-size: var(--text-lg);
  }

  :where(.Markdown h4) {
    font-size: var(--text-lg);
  }

  :where(.Markdown p) {
    margin-block-start: 1em;
    margin-block-end: 1em;
  }

  :where(.Markdown > :first-child) {
    margin-block-start: 0;
  }

  :where(.Markdown > :last-child) {
    margin-block-end: 0;
  }

  :where(.Markdown a) {
    color: var(--accent);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    transition: color var(--duration) var(--ease);
  }

  :where(.Markdown a:hover) {
    color: var(--accent-hover);
  }

  :where(.Markdown code):not(pre code) {
    background: var(--surface-alt);
    border-radius: var(--radius-sm);
    font-size: .875em;
    font-family: var(--font-mono);
    padding-block-start: .125em;
    padding-block-end: .125em;
    padding-inline-start: .375em;
    padding-inline-end: .375em;
  }

  :where(.Markdown pre) {
    padding: var(--space-md);
    background: var(--surface-alt);
    border-radius: var(--radius-md);
    overflow-x: auto;
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    margin-block-start: 1.5em;
    margin-block-end: 1.5em;
  }

  :where(.Markdown pre code) {
    font-size: inherit;
    background: none;
    border-radius: 0;
    padding: 0;
  }

  :where(.Markdown .shiki) {
    padding: var(--space-md);
    border-radius: var(--radius-md);
    overflow-x: auto;
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    margin-block-start: 1.5em;
    margin-block-end: 1.5em;
  }

  :where(.Markdown .shiki code) {
    background: none;
    padding: 0;
  }

  :where(.Markdown blockquote) {
    border-inline-start: 3px solid var(--accent);
    color: var(--muted);
    margin-block-start: 1.5em;
    margin-block-end: 1.5em;
    margin-inline-start: 0;
    margin-inline-end: 0;
    padding-inline-start: var(--space-md);
    font-style: italic;
  }

  :where(.Markdown blockquote p) {
    margin-block-start: .5em;
    margin-block-end: .5em;
  }

  :where(.Markdown ul) {
    margin-block-start: 1em;
    margin-block-end: 1em;
    padding-inline-start: 1.5em;
  }

  :where(.Markdown ol) {
    margin-block-start: 1em;
    margin-block-end: 1em;
    padding-inline-start: 1.5em;
  }

  :where(.Markdown li) {
    margin-block-start: .375em;
    margin-block-end: .375em;
  }

  :where(.Markdown li > ul) {
    margin-block-start: .25em;
    margin-block-end: .25em;
  }

  :where(.Markdown li > ol) {
    margin-block-start: .25em;
    margin-block-end: .25em;
  }

  :where(.Markdown ul) {
    list-style-type: disc;
  }

  :where(.Markdown ul ul) {
    list-style-type: circle;
  }

  :where(.Markdown ol) {
    list-style-type: decimal;
  }

  :where(.Markdown .Markdown-table-wrapper) {
    overflow-x: auto;
    margin-block-start: 1.5em;
    margin-block-end: 1.5em;
  }

  :where(.Markdown table) {
    border-collapse: collapse;
    font-size: var(--text-ui);
    inline-size: 100%;
  }

  :where(.Markdown th) {
    padding: var(--space-sm) var(--space-md);
    border: 1px solid var(--line);
    text-align: start;
  }

  :where(.Markdown td) {
    padding: var(--space-sm) var(--space-md);
    border: 1px solid var(--line);
    text-align: start;
  }

  :where(.Markdown th) {
    background: var(--surface-alt);
    font-weight: var(--weight-semibold);
  }

  :where(.Markdown tr:nth-child(2n) td) {
    background: color-mix(in oklab, var(--surface-alt) 50%, transparent);
  }

  :where(.Markdown hr) {
    border: none;
    border-block-start: 1px solid var(--line);
    margin-block-start: 2em;
    margin-block-end: 2em;
  }

  :where(.Markdown img) {
    border-radius: var(--radius-md);
    block-size: auto;
    max-inline-size: 100%;
  }

  :where(.Markdown a:has( > img)) {
    text-decoration: none;
    color: inherit;
  }

  :where(.Markdown strong) {
    font-weight: var(--weight-semibold);
  }

  :where(.Markdown em) {
    font-style: italic;
  }

  :where(.Markdown .InternalLink) {
    color: var(--accent);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    transition: color var(--duration) var(--ease);
  }

  :where(.Markdown .InternalLink:hover) {
    color: var(--accent-hover);
  }

  :where(.Markdown .InternalLink.is-broken) {
    color: var(--danger);
    text-decoration: line-through;
    text-decoration-color: var(--danger);
    cursor: not-allowed;
  }
}

/* packages/ui/src/styles/blocks/callout.css */
@layer components {
  :where(.callout) {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--space-sm);
    padding: var(--space-md);
    background: var(--callout-bg, var(--surface-alt));
    border-radius: var(--radius-md);
    border-inline-start: 3px solid var(--callout-accent, var(--accent));
    margin-block-start: 1.5em;
    margin-block-end: 1.5em;
  }

  :where(.callout-icon) {
    color: var(--callout-accent, var(--accent));
    flex-shrink: 0;
    block-size: 1.25rem;
    inline-size: 1.25rem;
  }

  :where(.callout-content) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
    min-inline-size: 0;
  }

  :where(.callout-title) {
    font-weight: var(--weight-semibold);
    font-size: var(--text-ui);
    color: var(--callout-accent, var(--accent));
  }

  :where(.callout-body) {
    font-size: var(--text-ui);
    line-height: var(--leading-relaxed);
    color: var(--ink);
  }

  :where(.callout-body) p {
    margin: 0;
  }

  :where(.callout-body) p + p {
    margin-block-start: var(--space-sm);
  }

  :where(.callout[data-variant="note"]) {
    --callout-bg: color-mix(in oklab, var(--accent) 8%, var(--paper));
    --callout-accent: var(--accent);
  }

  :where(.callout[data-variant="info"]) {
    --callout-bg: color-mix(in oklab, var(--info) 8%, var(--paper));
    --callout-accent: var(--info);
  }

  :where(.callout[data-variant="tip"]) {
    --callout-bg: color-mix(in oklab, var(--positive) 8%, var(--paper));
    --callout-accent: var(--positive);
  }

  :where(.callout[data-variant="warning"]) {
    --callout-bg: color-mix(in oklab, var(--warning) 8%, var(--paper));
    --callout-accent: var(--warning);
  }

  :where(.callout[data-variant="danger"]) {
    --callout-bg: color-mix(in oklab, var(--danger) 8%, var(--paper));
    --callout-accent: var(--danger);
  }
}

/* packages/ui/src/styles/blocks/app-grid.css */
@layer components {
  @keyframes app-grid-item-in {
    from {
      opacity: 0;
      translate: 0 6px;
    }

    to {
      opacity: 1;
      translate: 0;
    }
  }

  :where(.app-grid) {
    display: grid;
    --app-grid-min: 16rem;
    --app-grid-gap: var(--space-md);
    grid-template-columns: repeat(auto-fill, minmax(min(var(--app-grid-min), 100%), 1fr));
    gap: var(--app-grid-gap);
  }

  :where(.app-grid > *) {
    animation: app-grid-item-in var(--duration) ease-out both;
    animation-delay: calc(var(--stagger-index, 0) * 60ms);
  }
}

/* packages/ui/src/styles/blocks/children-grid.css */
@property --shine-x {
  syntax: "<percentage>";
  inherits: false;
  initial-value: -30%;
}

@property --shine-spread {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 8%;
}

@layer components {
  @keyframes children-grid-shine {
    0% {
      --shine-x: -30%;
      --shine-spread: 5%;
      opacity: 1;
    }

    35% {
      --shine-x: 130%;
      --shine-spread: 28%;
      opacity: .25;
    }

    35.1%, 100% {
      --shine-x: -30%;
      --shine-spread: 5%;
      opacity: 0;
    }
  }

  @keyframes children-grid-shine-hover {
    0% {
      --shine-x: -30%;
      --shine-spread: 5%;
      opacity: 1;
    }

    35% {
      --shine-x: 130%;
      --shine-spread: 28%;
      opacity: .25;
    }

    35.1%, 100% {
      --shine-x: -30%;
      --shine-spread: 5%;
      opacity: 0;
    }
  }

  :where(.children-grid) {
    margin-block: var(--space-md);
  }

  :where(.children-grid-title) {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    font-weight: var(--weight-semibold);
    margin-block-end: var(--space-md);
  }

  :where(.children-grid-link) {
    display: block;
    text-decoration: none;
    color: var(--ink);
  }

  :where(.children-grid-link:hover) {
    --cover-card-scale: scale(1.05);
  }

  :where(.children-grid-link[data-featured]) {
    position: relative;
    z-index: 0;
    transition: transform var(--duration) var(--ease);
  }

  :where(.children-grid-link[data-featured]):hover {
    transition-duration: calc(var(--duration) * 1.5);
    transform: scale(1.02);
  }

  :where(.children-grid-link[data-featured]):active {
    transform: scale(.98);
  }

  :where(.children-grid-link[data-featured]):before {
    content: "";
    position: absolute;
    z-index: -1;
    border-radius: calc(var(--surface-radius, var(--radius-lg))  + 1px);
    background: linear-gradient(135deg, color-mix(in oklab, var(--accent) 40%, white) 0%, var(--accent) 5%, var(--line) 15%, var(--line) 85%, var(--accent) 95%, color-mix(in oklab, var(--accent) 40%, white) 100%);
    inset: -1px;
  }

  :where(.children-grid-card) {
    --card-padding: var(--space-md);
    color: var(--ink);
    block-size: 100%;
  }

  :where(.children-grid-card[data-featured]) {
    --surface-shadow: var(--shadow-card);
  }

  .children-grid-card[data-featured]:hover, .children-grid-card[data-featured]:active {
    transform: none;
  }

  :where(.children-grid-card .card-header) {
    animation: children-grid-content-fade-in .5s ease-out both;
  }

  :where(.children-grid-tags) {
    position: relative;
    z-index: 1;
    display: flex;
    gap: var(--space-xs);
    flex-wrap: wrap;
  }

  :where(.children-grid-featured-wrap) {
    position: relative;
    z-index: 1;
    display: inline-flex;
    border-radius: var(--radius-full);
    overflow: hidden;
    align-self:  flex-start;
    padding: 1px;
  }

  :where(.children-grid-featured-wrap):after {
    content: "";
    position: absolute;
    background: linear-gradient(110deg, var(--line) calc(var(--shine-x)  - var(--shine-spread, 8%)), var(--accent) calc(var(--shine-x)  - 2%), color-mix(in oklab, var(--accent) 40%, white) var(--shine-x), var(--accent) calc(var(--shine-x)  + 2%), var(--line) calc(var(--shine-x)  + var(--shine-spread, 8%)));
    animation: children-grid-shine 6s ease-in .5s 1 both;
    inset: 0;
  }

  :where(.children-grid-link[data-featured]:hover .children-grid-featured-wrap):after {
    animation: children-grid-shine-hover 6s ease-in 1 both;
  }

  :where(.children-grid-featured-badge) {
    --badge-bg: color-mix(in oklab, var(--surface) 80%, var(--accent));
    --badge-fg: var(--accent);
    --badge-px: var(--space-md);
    --badge-py: var(--space-sm);
    --badge-fs: var(--text-base);
    position: relative;
    z-index: 1;
  }

  :where(.children-grid-featured-badge) svg {
    block-size: .85em;
    inline-size: .85em;
  }

  @keyframes children-grid-content-fade-in {
    from {
      opacity: 0;
    }

    to {
      opacity: 1;
    }
  }
}

/* packages/ui/src/styles/blocks/radio-card.css */
@layer components {
  :where(.radio-card-group) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.radio-card-group[data-orientation="horizontal"]) {
    flex-flow: wrap;
  }

  :where(.radio-card) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
    padding: var(--space-md);
    border: 1.5px solid var(--line);
    border-radius: var(--radius-lg);
    cursor: pointer;
    user-select: none;
    transition: border-color var(--duration) var(--ease), background var(--duration) var(--ease), box-shadow var(--duration) var(--ease);
  }

  :where(.radio-card):hover:not([data-disabled]) {
    border-color: color-mix(in oklab, var(--accent) 60%, var(--line));
    background: color-mix(in oklab, var(--accent) 5%, transparent);
  }

  :where(.radio-card)[data-checked] {
    border-color: var(--accent);
    background: color-mix(in oklab, var(--accent) 8%, var(--surface));
    box-shadow: 0 0 0 .5px var(--accent);
  }

  :where(.radio-card)[data-disabled] {
    opacity: .5;
    cursor: not-allowed;
  }

  :where(.radio-card-indicator) {
    border: 1.5px solid var(--line);
    position: relative;
    transition: border-color var(--duration) var(--ease);
    border-radius: 50%;
    flex-shrink: 0;
    block-size: 1rem;
    inline-size: 1rem;
    margin-inline-start: auto;
  }

  :where(.radio-card-indicator):after {
    content: "";
    position: absolute;
    background: var(--accent);
    opacity: 0;
    transition: opacity var(--duration) var(--ease), transform var(--duration) var(--ease);
    border-radius: 50%;
    inset: 2px;
    transform: scale(.5);
  }

  :where(.radio-card[data-checked] .radio-card-indicator) {
    border-color: var(--accent);
  }

  :where(.radio-card[data-checked] .radio-card-indicator):after {
    opacity: 1;
    transform: scale(1);
  }

  :where(.radio-card-icon) {
    display: flex;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface-alt);
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
    block-size: 2rem;
    inline-size: 2rem;
  }

  :where(.radio-card-icon) svg:not([class*="size-"]) {
    inline-size: var(--space-md);
    block-size: var(--space-md);
  }

  :where(.radio-card-content) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
    flex: 1;
    min-inline-size: 0;
  }

  :where(.radio-card-title) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    line-height: var(--leading-normal);
  }

  :where(.radio-card-description) {
    font-size: var(--text-ui);
    color: var(--muted);
    line-height: var(--leading-normal);
  }
}

/* packages/ui/src/styles/blocks/protected-media.css */
@layer components {
  :where(.VideoLayerRoot) {
    position: relative;
  }

  :where(.VideoLayer) {
    position: absolute;
    pointer-events: none;
    z-index: 1;
    inset: 0;
  }

  :where(.VideoLayerIframe) {
    border-radius: var(--radius-md);
    border: none;
    width: 100%;
    height: 100%;
  }

  :where(.ProtectedVideo, .ProtectedImage) {
    position: relative;
    margin-block: var(--space-lg);
    border-radius: var(--radius-md);
    overflow: hidden;
  }

  :where(.ProtectedVideo-wrapper) {
    position: relative;
    background: oklch(0 0 0);
    border-radius: var(--radius-md);
    overflow: hidden;
    padding-block-start: 56.25%;
  }

  :where(.ProtectedVideo-placeholder, .ProtectedImage-placeholder) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-md);
    padding: var(--space-xl);
    background: var(--surface-alt);
    border: 2px dashed var(--line);
    border-radius: var(--radius-md);
    color: var(--muted);
  }

  :where(.ProtectedVideo-icon, .ProtectedImage-icon) {
    opacity: .5;
    flex-shrink: 0;
    block-size: 2rem;
    inline-size: 2rem;
  }

  :where(.ProtectedVideo-info, .ProtectedImage-info) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
  }

  :where(.ProtectedVideo-label, .ProtectedImage-label) {
    font-weight: var(--weight-medium);
    color: var(--ink);
  }

  :where(.ProtectedVideo-error, .ProtectedImage-error) {
    font-size: var(--text-ui);
    color: var(--danger);
  }

  :where(.ProtectedVideo-caption, .ProtectedImage-caption) {
    font-size: var(--text-ui);
    color: var(--muted);
    text-align: center;
    margin-block-start: var(--space-sm);
  }

  :where(.ProtectedImage-wrapper) {
    position: relative;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: none;
  }

  :where(.ProtectedImage-wrapper) .media-image {
    display: block;
  }

  :where(.ProtectedVideo-badge, .ProtectedImage-badge) {
    position: absolute;
    top: var(--space-sm);
    right: var(--space-sm);
    z-index: 1;
    display: inline-flex;
    padding-inline: var(--space-xs);
    padding-block: var(--space-xs);
    font-family: var(--font-body);
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: .05em;
    background: var(--accent);
    color: var(--on-accent);
    border-radius: var(--radius-sm);
    align-items:  center;
  }

  :where(.ProtectedVideo[data-paywall], .ProtectedImage[data-paywall]) .ProtectedVideo-wrapper {
    border: 2px solid var(--accent);
  }

  :where(.ProtectedVideo[data-paywall], .ProtectedImage[data-paywall]) .ProtectedVideo-placeholder {
    border-color: var(--accent);
    border-style: solid;
  }

  :where(.ProtectedVideo[data-paywall], .ProtectedImage[data-paywall]) .ProtectedImage-placeholder {
    border-color: var(--accent);
    border-style: solid;
  }
}

/* packages/ui/src/styles/blocks/fade-image.css */
@layer components {
  :where(.fade-image) {
    opacity: 0;
    transition: opacity var(--duration) var(--ease);
  }

  :where(.fade-image)[data-loaded] {
    opacity: 1;
  }
}

/* packages/ui/src/styles/blocks/media-image.css */
@layer components {
  @keyframes media-image-placeholder-enter {
    from {
      opacity: 0;
    }

    to {
      opacity: 1;
    }
  }

  :where(.media-image) {
    position: relative;
    display: block;
    overflow: hidden;
    background-color: #0000;
    block-size: 100%;
  }

  :where(.media-image-placeholder) {
    position: absolute;
    object-fit: cover;
    filter: blur(20px);
    opacity: 1;
    animation: media-image-placeholder-enter .3s ease-out;
    block-size: 100%;
    inline-size: 100%;
    transition: opacity .3s ease-out;
    inset: 0;
    transform: scale(1.1);
  }

  :where(.media-image-img) {
    position: relative;
    object-fit: cover;
    opacity: 0;
    block-size: 100%;
    inline-size: 100%;
    transition: opacity .3s ease-out;
  }

  :where(.media-image-img[data-loaded]) {
    opacity: 1;
  }

  .media-image:has(.media-image-img[data-loaded]) .media-image-placeholder {
    opacity: 0;
    pointer-events: none;
    transition-delay: .3s;
  }

  :where(.media-image[data-instant]) .media-image-placeholder {
    display: none;
  }

  :where(.media-image[data-instant]) .media-image-img {
    opacity: 1;
    transition: none;
  }
}

/* packages/ui/src/styles/blocks/toc.css */
@layer components {
  :where(.toc) {
    position: sticky;
    max-block-size: calc(100vh - 4.25rem - var(--space-lg));
    overflow-y: auto;
    font-size: var(--text-ui);
    top: 4.25rem;
  }

  :where(.toc-title) {
    font-weight: var(--weight-semibold);
    font-size: var(--text-caption);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--muted);
    margin-block-end: var(--space-sm);
  }

  :where(.toc-list) {
    list-style: none;
    display: flex;
    gap: var(--space-2xs);
    flex-direction: column;
    margin: 0;
    padding: 0;
  }

  :where(.toc-item) {
    padding-inline-start: calc(var(--toc-indent, 0) * var(--space-md));
  }

  :where(.toc-link) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    padding-block: var(--space-2xs);
    color: var(--muted);
    text-decoration: none;
    transition: color var(--duration) var(--ease);
    border-inline-start: 2px solid #0000;
    margin-inline-start: calc(-1 * var(--space-sm)  - 2px);
    padding-inline-start: var(--space-sm);
  }

  :where(.toc-link [data-slot="truncate"]) {
    --truncate-fade: 1.5rem;
    flex: 1;
  }

  :where(.toc-dot) {
    background: var(--line);
    transition: background var(--duration) var(--ease);
    border-radius: 50%;
    flex-shrink: 0;
    block-size: 6px;
    inline-size: 6px;
  }

  :where(.toc-dot[data-past]) {
    background: var(--accent);
  }

  :where(.toc-link:hover) {
    color: var(--ink);
  }

  :where(.toc-link:focus-visible) {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
    border-radius: var(--radius-sm);
  }

  :where(.toc-link[aria-current="true"]) {
    color: var(--accent);
    border-inline-start-color: var(--accent);
    font-weight: var(--weight-medium);
  }

  :where(.toc-link.is-active) {
    color: var(--accent);
    border-inline-start-color: var(--accent);
    font-weight: var(--weight-medium);
  }
}

/* packages/ui/src/styles/blocks/title-back-nav.css */
@layer components {
  :where(.title-back-nav) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
  }

  :where(.title-back-nav-back) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-2xs);
    font-size: var(--text-ui);
    color: var(--muted);
    text-decoration: none;
    cursor: pointer;
    border-radius: var(--radius-sm);
    font: inherit;
    background: none;
    border: 0;
    align-self:  flex-start;
    padding: 0;
  }

  :where(.title-back-nav-back):hover {
    color: var(--ink);
  }

  :where(.title-back-nav-back):focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
  }

  :where(.title-back-nav-icon) {
    flex-shrink: 0;
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.title-back-nav-title) {
    font-size: var(--text-2xl);
    font-weight: var(--weight-bold);
    letter-spacing: -.02em;
    margin: 0;
    line-height: 1.15;
  }
}

/* packages/ui/src/styles/blocks/content-page.css */
@layer components {
  @keyframes content-page-fade-in {
    from {
      opacity: 0;
      transform: translateY(var(--space-xs));
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  :where(.content-page) {
    --content-page-sticky-offset: 5.5rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
    align-items:  start;
  }

  :where(.content-page-body) {
    display: grid;
    grid-template-columns: 1fr 14rem;
    gap: var(--space-lg);
    max-inline-size: calc(90ch + var(--space-lg)  + 14rem);
    align-items:  start;
  }

  :where(.content-page-body)[data-no-toc] {
    display: flex;
    grid-template-columns: none;
    flex-direction: column;
    align-items: stretch;
    max-inline-size: 90ch;
  }

  :where(.content-page-content) {
    animation: content-page-fade-in .2s ease-out;
    min-inline-size: 0;
  }

  :where(.content-page-header) {
    max-inline-size: 90ch;
    margin-block-end: var(--space-lg);
  }

  @media (min-width: 64rem) {
    :where(.content-page-content):has(.content-page-body) :where(.content-page-header) {
      max-inline-size: calc(100% - var(--space-lg)  - 14rem);
    }
  }

  :where(.content-page-h1) {
    font-size: var(--text-4xl);
    font-weight: var(--weight-bold);
    letter-spacing: -.03em;
    text-wrap: balance;
    margin: 0;
    line-height: 1.1;
  }

  :where(.content-page-h1-row) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
    flex-wrap: wrap;
  }

  :where(.content-page-h1-row) > :where(.content-page-h1) {
    flex: 0 auto;
    min-inline-size: 0;
  }

  :where(.content-page-identity) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.content-page-identity) > :where(.badge) {
    align-self:  flex-start;
  }

  :where(.title-back-nav, .content-page-h1) {
    min-inline-size: 0;
  }

  :where(.title-back-nav-title) {
    text-wrap: balance;
  }

  :where(.content-page-toggle-indicators) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-xs);
    vertical-align: middle;
    color: var(--accent);
    margin-inline-start: var(--space-sm);
  }

  :where(.content-page-toggle-indicator) {
    display: inline-flex;
    color: inherit;
    cursor: pointer;
    border-radius: var(--radius-sm);
    background: none;
    border: none;
    padding: 0;
  }

  :where(.content-page-toggle-indicator):hover {
    opacity: .7;
  }

  :where(.content-page-toggle-indicator):focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
  }

  :where(.content-page-toggle-indicator) :where(svg) {
    inline-size: var(--text-ui);
    block-size: var(--text-ui);
  }

  :where(.content-page-menu) {
    display: inline-flex;
    white-space: nowrap;
    vertical-align: middle;
    margin-inline-start: var(--space-md);
  }

  :where(.content-page-menu-trigger) {
    --button-font-size: var(--text-ui);
    position: relative;
    isolation: isolate;
    overflow: hidden;
    border-radius: var(--radius-full);
    color: color-mix(in oklab, var(--ink) 84%, var(--paper));
    background: radial-gradient(140% 180% at 0% 0%, color-mix(in oklab, var(--accent) 12%, transparent), transparent 50%), linear-gradient(180deg, color-mix(in oklab, var(--paper) 36%, transparent), color-mix(in oklab, var(--surface) 84%, transparent));
    border-color: color-mix(in oklab, var(--line) 55%, transparent);
    backdrop-filter: blur(16px) saturate(1.24);
    box-shadow: var(--shadow-md), var(--shadow-card);
  }

  :where(.content-page-menu-trigger):before {
    content: "";
    position: absolute;
    border-radius: inherit;
    background: linear-gradient(180deg, color-mix(in oklab, var(--paper) 34%, transparent), color-mix(in oklab, var(--surface) 8%, transparent));
    opacity: .88;
    pointer-events: none;
    z-index: -1;
    inset: 1px;
  }

  :where(.content-page-menu-trigger):hover:not(:disabled) {
    color: var(--ink);
    border-color: color-mix(in oklab, var(--accent) 36%, var(--line));
    background: radial-gradient(140% 180% at 0% 0%, color-mix(in oklab, var(--accent) 16%, transparent), transparent 52%), linear-gradient(180deg, color-mix(in oklab, var(--paper) 40%, transparent), color-mix(in oklab, var(--surface) 88%, transparent));
    box-shadow: var(--shadow-lg), var(--shadow-card);
  }

  :where(.content-page-menu-trigger) svg {
    block-size: 1.35em;
    inline-size: 1.35em;
  }

  :where(.content-page-menu-panel) {
    white-space: nowrap;
    min-inline-size: min(calc(var(--space-lg) * 11), calc(100vw - var(--space-lg) * 2));
    max-block-size: min(var(--available-height, calc(var(--space-xl) * 6.25)), calc(100dvh - var(--space-xl)));
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
  }

  :where(.content-page-menu-listen-icon) {
    color: var(--accent) !important;
  }

  :where(.content-page-engagement) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    min-block-size: 2.25rem;
    margin-block-start: var(--space-sm);
  }

  :where(.content-page-modalities) {
    min-inline-size: 0;
    max-inline-size: 28rem;
    margin-block-start: var(--space-md);
  }

  :where(.content-page-tools) {
    margin-inline-start: auto;
  }

  :where(.content-page-not-found-editable) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.content-toggles-group) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    border: none;
  }

  :where(.content-page-meta) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    font-size: var(--text-xs);
    color: var(--muted);
  }

  :where(.content-page-meta-dot) {
    user-select: none;
  }

  :where(.content-page-modalities) :where(.audio-player) {
    max-inline-size: 28rem;
  }

  :where(.content-page-modalities[data-pip]):has(.audio-player) {
    position: fixed;
    bottom: var(--space-xl);
    z-index: var(--z-overlay);
    inline-size: min(28rem, calc(100vw - var(--space-xl) * 2));
    interpolate-size: allow-keywords;
    transition: inline-size var(--duration) var(--ease);
    left: 50vw;
    transform: translateX(-50%);
  }

  @media (prefers-reduced-motion: no-preference) {
    :where(.content-page-modalities[data-pip]):has(.audio-player) {
      animation: pip-enter .2s var(--ease) both;
    }
  }

  @keyframes pip-enter {
    from {
      opacity: 0;
      translate: 0 var(--space-md);
    }

    to {
      opacity: 1;
      translate: 0;
    }
  }

  @keyframes pip-exit {
    from {
      opacity: 1;
      translate: 0;
    }

    to {
      opacity: 0;
      translate: 0 var(--space-md);
    }
  }

  :where(.content-page-modalities[data-pip]):has(.audio-player) :where(.audio-player) {
    box-shadow: 0 0 0 1px var(--line), var(--shadow-md);
  }

  @media (prefers-reduced-motion: no-preference) {
    :where(.content-page-modalities[data-pip][data-pip-closing]):has(.audio-player) {
      animation: pip-exit .2s var(--ease) both;
    }
  }

  @media (prefers-reduced-motion: reduce) {
    :where(.content-page-modalities[data-pip][data-pip-closing]):has(.audio-player) {
      opacity: 0;
    }
  }

  :where(.content-page-listen-loading) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-xs);
    font-size: var(--text-ui);
    color: var(--muted);
    padding-block: var(--space-xs);
  }

  :where(.content-page-listen-loading-spinner) {
    flex-shrink: 0;
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.content-page-listen-button) svg {
    color: var(--accent);
  }

  :where(.content-page-listen-ai-label) {
    color: var(--muted);
  }

  :where(.content-page-sidebar) {
    position: sticky;
    top: var(--content-page-sticky-offset);
  }

  @media (max-width: calc(64rem - .001px)) {
    :where(.content-page-body) {
      grid-template-columns: 1fr;
    }

    :where(.content-page-sidebar) {
      display: none;
    }
  }

  :where(.toggle-list-page-header) {
    margin-block-end: var(--space-lg);
  }

  :where(.toggle-list-page-title) {
    font-size: var(--text-3xl);
    font-weight: var(--weight-bold);
    letter-spacing: -.02em;
    margin: 0;
  }

  :where(.toggle-list-page-description) {
    color: var(--muted);
    margin-block-start: var(--space-xs);
  }

  :where(.toggle-list-page-count) {
    display: block;
    font-size: var(--text-ui);
    color: var(--muted);
    margin-block-start: var(--space-xs);
  }

  :where(.toggle-list-page-list) {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  :where(.toggle-list-page-item) {
    border-radius: var(--radius-md);
    background: var(--surface);
    border: 1px solid var(--line);
    transition: all var(--duration) var(--ease);
  }

  :where(.toggle-list-page-item):hover {
    border-color: var(--accent);
    box-shadow: var(--shadow-sm);
  }

  :where(.toggle-list-page-item-link) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-md);
    padding: var(--space-md);
    text-decoration: none;
    color: inherit;
  }

  :where(.toggle-list-page-item-main) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    min-inline-size: 0;
  }

  :where(.toggle-list-page-item-title) {
    font-weight: var(--weight-medium);
    color: var(--ink);
  }

  :where(.toggle-list-page-item-badges) {
    display: flex;
    align-items:  center;
    gap: var(--space-2xs);
    opacity: .85;
    flex-shrink: 0;
  }

  :where(.toggle-list-page-item-date) {
    font-size: var(--text-ui);
    color: var(--muted);
    flex-shrink: 0;
  }

  :where(.toggle-list-group-header) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
  }

  :where(.toggle-list-group-trigger) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding-block: var(--space-sm);
    font-weight: var(--weight-medium);
    text-align: start;
    flex: 1;
    min-inline-size: 0;
  }

  :where(.toggle-list-group-trigger-title) {
    flex: 1;
    min-inline-size: 0;
  }

  :where(.toggle-list-group-chevron) {
    transition: transform var(--duration) var(--ease);
    flex-shrink: 0;
  }

  :where([data-state="open"] .toggle-list-group-chevron) {
    transform: rotate(180deg);
  }

  :where(.toggle-list-group-link-btn) {
    display: flex;
    padding: var(--space-xs);
    color: var(--muted);
    border-radius: var(--radius-sm);
    text-decoration: none;
    transition: color var(--duration) var(--ease);
    flex-shrink: 0;
    justify-content: center;
    align-items:  center;
  }

  :where(.toggle-list-group-link-btn):hover {
    color: var(--ink);
  }

  :where(.toggle-list-group-link-btn):focus-visible {
    color: var(--ink);
  }

  :where(.content-page-preview-banner) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-md);
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-ui);
    color: var(--ink);
    background: var(--tint-warning);
    border: 1px solid color-mix(in oklab, var(--accent) 30%, transparent);
    border-radius: var(--radius-md);
    margin-block-end: var(--space-md);
  }

  :where(.content-page-preview-banner) > a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: .2em;
  }

  :where(.content-page-preview-banner) > a:hover {
    text-decoration-thickness: 2px;
  }

  :where(.content-page-preview-banner) > a:focus-visible {
    text-decoration-thickness: 2px;
  }

  :where(.content-page-media-hero) {
    margin: var(--space-md) 0 var(--space-lg);
  }

  :where(.content-page-media-hero) > figure {
    object-fit: contain;
    border-radius: var(--radius-md);
    width: 100%;
    max-height: 70vh;
  }

  :where(.content-page-media-hero) :where(img, video, iframe) {
    object-fit: contain;
    border-radius: var(--radius-md);
    width: 100%;
    max-height: 70vh;
  }

  :where(.content-page-short) {
    display: flex;
    min-height: calc(100dvh - var(--app-shell-header-height, 0px));
    padding: var(--space-md);
    justify-content: center;
    align-items:  flex-start;
  }

  :where(.content-page-short-stage) {
    position: relative;
    max-inline-size: min(100%, calc((100dvh - var(--app-shell-header-height, 0px)  - var(--space-md) * 2) * 16 / 9));
    border-radius: var(--radius-md);
    overflow: hidden;
    background: #000;
    background: lab(0% 0 0);
    inline-size: 100%;
  }

  :where(.content-page-short-stage)[data-aspect="vertical"] {
    max-inline-size: min(100%, calc((100dvh - var(--app-shell-header-height, 0px)  - var(--space-md) * 2) * 9 / 16));
  }

  :where(.content-page-short-stage) :where(.content-page-media-hero, figure, .ProtectedVideo, .ProtectedImage) {
    inline-size: 100%;
    max-inline-size: 100%;
    margin: 0;
  }

  :where(.content-page-short-stage) :where(figcaption) {
    display: none;
  }

  :where(.content-page-short-stage) :where(img, video) {
    object-fit: contain;
    display: block;
    max-block-size: 100%;
    max-inline-size: 100%;
  }

  :where(.content-page-short-overlay) {
    position: absolute;
    z-index: 2;
    display: flex;
    justify-content: flex-start;
    align-items:  flex-start;
    gap: calc(var(--space-xs) / 2);
    padding: var(--space-md);
    pointer-events: none;
    color: #fff;
    color: color(display-p3 1 1 1);
    color: lab(100% 0 0);
    text-shadow: 0 1px 2px var(--scrim), 0 0 8px oklch(0 0 0 / .25);
    flex-direction: column;
    inset: 0;
  }

  :where(.content-page-short-overlay-title) {
    font-size: clamp(var(--text-lg), 2.4vw, var(--text-xl));
    font-weight: var(--weight-semibold);
    letter-spacing: -.01em;
    max-inline-size: min(48ch, 85%);
    margin: 0;
    line-height: 1.2;
  }

  :where(.content-page-short-overlay-body) {
    font-size: clamp(var(--text-sm), 1.2vw, var(--text-ui));
    max-inline-size: min(48ch, 85%);
    line-height: 1.35;
  }

  :where(.content-page-short-overlay-body) {
    color: inherit;
  }

  :where(.content-page-short-overlay-body) * {
    color: inherit;
  }

  :where(.content-page-short-overlay-body) :where(p) {
    margin: 0;
  }
}

@layer components {
  :where(.content-feed) {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 18rem), 1fr));
    gap: var(--space-md);
    margin: 0;
    padding: 0;
  }

  :where(.content-feed-item) {
    display: contents;
  }

  :where(.content-feed-card) {
    display: grid;
    grid-template-rows: auto 1fr;
    gap: var(--space-sm);
    border-radius: var(--radius-md);
    background: var(--surface);
    color: inherit;
    text-decoration: none;
    overflow: hidden;
    padding: 0;
    transition: transform .12s, box-shadow .12s;
  }

  :where(.content-feed-card):hover {
    box-shadow: 0 4px 14px color-mix(in oklab, var(--ink) 12%, transparent);
    transform: translateY(-2px);
  }

  :where(.content-feed-card):focus-visible {
    box-shadow: 0 4px 14px color-mix(in oklab, var(--ink) 12%, transparent);
    transform: translateY(-2px);
  }

  :where(.content-feed-card) > :where(figure, img) {
    aspect-ratio: 16 / 10;
    object-fit: cover;
    background: var(--surface-strong, color-mix(in oklab, var(--surface) 92%, var(--ink) 8%));
    width: 100%;
    margin: 0;
  }

  [data-kind="image"] > :where(.content-feed-card) > :where(figure, img) {
    aspect-ratio: 1;
  }

  [data-kind="short"] > :where(.content-feed-card) > :where(figure, img) {
    aspect-ratio: 9 / 16;
  }

  :where(.content-feed-card-placeholder) {
    aspect-ratio: 16 / 10;
    background: var(--surface-strong, color-mix(in oklab, var(--surface) 92%, var(--ink) 8%));
    width: 100%;
  }

  :where(.content-feed-card-meta) {
    padding: var(--space-sm) var(--space-md) var(--space-md);
  }

  :where(.content-feed-card-title) {
    margin: 0 0 var(--space-2xs);
    font-size: var(--text-ui);
    font-weight: 600;
    line-height: 1.3;
  }

  :where(.content-feed-card-description) {
    font-size: var(--text-caption);
    color: var(--ink-muted);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    overflow: hidden;
    -webkit-box-orient: vertical;
    margin: 0;
    line-height: 1.4;
  }
}

/* packages/ui/src/styles/blocks/content-editor.css */
@layer components {
  :where(.base-markdown-editor) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
  }

  :where(.base-markdown-editor-panel) {
    display: flex;
    border-radius: var(--radius-md);
    background: var(--surface);
    border: 1px solid var(--line);
    overflow: hidden;
    transition: border-color var(--duration) var(--ease);
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
  }

  :where(.base-markdown-editor-panel):focus-within {
    border-color: var(--accent);
  }

  :where(.base-markdown-editor-panel-header) {
    display: flex;
    padding: var(--space-sm) var(--space-md);
    border-block-end: 1px solid var(--line);
    background: var(--surface-alt);
    justify-content: space-between;
    align-items:  center;
    min-block-size: 2.75rem;
  }

  :where(.base-markdown-editor-panel-header-left) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
  }

  :where(.base-markdown-editor-panel-title) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .05em;
  }

  :where(.base-markdown-editor-panel-stats) {
    font-size: var(--text-caption);
    color: var(--muted);
    opacity: .75;
  }

  :where(.base-markdown-editor-panel-actions) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.base-markdown-editor-textarea-wrapper) {
    position: relative;
    display: flex;
    overflow: hidden;
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
  }

  :where(.base-markdown-editor-textarea) {
    padding: var(--space-md);
    font-family: var(--font-mono);
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--ink);
    resize: none;
    outline: none;
    overflow-y: auto;
    background: none;
    border: none;
    flex: 1;
    min-block-size: 0;
  }

  :where(.base-markdown-editor-textarea)::placeholder {
    color: var(--muted);
  }

  :where(.content-editor) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    block-size: 100%;
    min-block-size: 0;
  }

  :where(.content-editor-status) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.content-editor-status-link) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-3xs);
    text-decoration: none;
    cursor: pointer;
    transition: background-color var(--duration) var(--ease), color var(--duration) var(--ease);
  }

  :where(.content-editor-status-link):hover {
    filter: brightness(1.08);
  }

  :where(.content-editor-status-link):focus-visible {
    filter: brightness(1.08);
  }

  :where(.content-editor-status-link) > .content-editor-status-link-icon {
    opacity: .55;
    transition: opacity var(--duration) var(--ease);
    block-size: .85em;
    inline-size: .85em;
  }

  :where(.content-editor-status-link):hover > .content-editor-status-link-icon {
    opacity: 1;
  }

  :where(.content-editor-status-link):focus-visible > .content-editor-status-link-icon {
    opacity: 1;
  }

  :where(.content-editor-toolbar) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
  }

  :where(.content-editor-layout) {
    display: flex;
    flex: 1;
    min-block-size: 0;
  }

  :where(.content-editor-panel) {
    display: flex;
    border-radius: var(--radius-md);
    background: var(--surface);
    border: 1px solid var(--line);
    overflow: hidden;
    transition: border-color var(--duration) var(--ease);
    flex-direction: column;
    min-block-size: 0;
  }

  :where(.content-editor-panel):focus-within {
    border-color: var(--accent);
  }

  :where(.content-editor-panel-header) {
    display: flex;
    padding: var(--space-sm) var(--space-md);
    border-block-end: 1px solid var(--line);
    background: var(--surface-alt);
    justify-content: space-between;
    align-items:  center;
    min-block-size: 2.75rem;
  }

  :where(.content-editor-panel-header-left) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
  }

  :where(.content-editor-panel-title) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .05em;
  }

  :where(.content-editor-panel-stats) {
    font-size: var(--text-caption);
    color: var(--muted);
    opacity: .75;
  }

  :where(.content-editor-panel-actions) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.base-markdown-editor-save-state) {
    display: inline-flex;
    color: var(--muted);
    border-radius: var(--radius-sm);
    justify-content: center;
    align-items:  center;
  }

  :where(.base-markdown-editor-save-state):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.content-editor-save-state) {
    font-size: var(--text-caption);
    color: var(--muted);
  }

  :where(.content-editor-save-state)[data-state="dirty"] {
    color: var(--warning);
  }

  :where(.content-editor-save-state)[data-state="saving"] {
    color: var(--accent);
  }

  :where(.content-editor-save-state)[data-state="saved"] {
    color: var(--positive);
  }

  :where(.content-editor-save-state)[data-state="error"] {
    color: var(--danger);
  }

  :where(.content-editor-button) {
    display: inline-flex;
    border-radius: var(--radius-sm);
    color: var(--muted);
    cursor: pointer;
    transition: all var(--duration) var(--ease);
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
    block-size: 1.75rem;
    inline-size: 1.75rem;
  }

  :where(.content-editor-button):hover {
    background: var(--surface);
    color: var(--ink);
  }

  :where(.content-editor-button) svg {
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.content-editor-textarea-wrapper) {
    position: relative;
    display: flex;
    overflow: hidden;
    flex-direction: column;
    flex: 1;
    min-block-size: 0;
  }

  :where(.content-editor-textarea) {
    padding: var(--space-md);
    font-family: var(--font-mono);
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--ink);
    resize: none;
    outline: none;
    overflow-y: auto;
    background: none;
    border: none;
    flex: 1;
    min-block-size: 0;
  }

  :where(.content-editor-textarea)::placeholder {
    color: var(--muted);
  }

  :where(.inline-content-editor) {
    position: absolute;
    display: flex;
    flex-direction: column;
    inset: 0;
  }

  :where(.inline-content-editor-header) {
    padding-block-end: var(--space-md);
  }

  :where(.create-content-dialog-form, .create-page-dialog-form) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.create-content-dialog-url-preview, .create-page-dialog-url-preview) {
    font-size: var(--text-caption);
    color: var(--muted);
    margin: 0;
  }

  :where(.media-content-editor) {
    display: flex;
    gap: var(--space-lg);
    flex-direction: column;
    inline-size: 100%;
    min-inline-size: 0;
    max-inline-size: 50rem;
    margin-inline-start: auto;
    margin-inline-end: auto;
  }

  :where(.media-content-editor-header) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    padding-block-end: var(--space-sm);
  }

  :where(.media-content-editor-status-row) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
    flex-wrap: wrap;
  }

  :where(.media-content-editor-status-actions) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    margin-inline-start: auto;
  }

  :where(.media-content-editor-header-actions) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-md);
    font-family: var(--font-sans);
    font-weight: normal;
    font-size: var(--text-ui);
    margin-inline-start: var(--space-md);
  }

  :where(.media-content-editor-kind-icon) {
    display: inline-flex;
    color: var(--muted);
    opacity: .7;
    vertical-align: -.1em;
    justify-content: center;
    align-items:  center;
    margin-inline-end: var(--space-sm);
  }

  :where(.media-content-editor-kind-icon) > svg {
    stroke-width: 1.75;
    block-size: .6em;
    inline-size: .6em;
  }

  :where(.media-content-editor-preview) {
    display: flex;
    flex-direction: column;
  }

  :where(.media-content-editor-preview) :where(.content-page-media-hero, .ProtectedVideo, .ProtectedImage) {
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    margin: 0;
  }

  :where(.media-content-editor-preview) .content-page-media-hero :where(img, video, iframe) {
    max-height: 60vh;
  }

  :where(.media-content-editor-preview) :where(figcaption) {
    display: none;
  }

  :where(.media-content-editor-preview-empty) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-2xs);
    aspect-ratio: 16 / 9;
    padding: var(--space-lg);
    background: linear-gradient(180deg, var(--surface-alt), color-mix(in oklab, var(--surface-alt) 70%, var(--paper)));
    border-radius: var(--radius-lg);
    color: var(--muted);
    text-align: center;
    flex-direction: column;
  }

  :where(.media-content-editor-preview-empty-icon) {
    color: var(--line);
    block-size: 2rem;
    inline-size: 2rem;
    margin-block-end: var(--space-2xs);
  }

  :where(.media-content-editor-preview-empty-title) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    color: var(--ink);
    margin: 0;
  }

  :where(.media-content-editor-preview-empty-hint) {
    font-size: var(--text-caption);
    margin: 0;
  }

  :where(.media-content-editor-fields) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    min-inline-size: 0;
  }

  :where(.media-content-editor-asset-card) {
    position: relative;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
    grid-template-areas: "label  label  actions" "thumb  body   actions";
    column-gap: var(--space-md);
    row-gap: var(--space-2xs);
    padding: var(--space-sm);
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    text-align: start;
    transition: border-color .18s var(--ease), background-color .18s var(--ease), box-shadow .18s var(--ease);
    padding-inline-end: var(--space-xs);
  }

  :where(.media-content-editor-asset-card):hover:not(.is-empty) {
    border-color: color-mix(in oklab, var(--ink) 18%, transparent);
    box-shadow: 0 2px 6px -2px #0000000f;
  }

  :where(button.media-content-editor-asset-card) {
    cursor: pointer;
    font: inherit;
    color: inherit;
    inline-size: 100%;
  }

  :where(button.media-content-editor-asset-card):hover {
    border-color: var(--accent);
    background: color-mix(in oklab, var(--accent) 4%, var(--surface));
  }

  :where(button.media-content-editor-asset-card):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.media-content-editor-asset-card.is-empty) {
    background: none;
    border-style: dashed;
  }

  :where(.media-content-editor-asset-card-label) {
    grid-area: label;
    font-size: .6875rem;
    font-weight: var(--weight-semibold);
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .06em;
    padding-block-end: var(--space-3xs);
    line-height: 1;
  }

  :where(.media-content-editor-asset-card-thumb) {
    grid-area: thumb;
  }

  :where(.media-content-editor-asset-card-body) {
    grid-area: body;
  }

  :where(.media-content-editor-asset-card-actions) {
    grid-area: actions;
    align-self:  center;
  }

  :where(.media-content-editor-asset-card > .button) {
    grid-area: actions;
    align-self:  center;
  }

  :where(.media-content-editor-asset-card-thumb) {
    position: relative;
    border-radius: var(--radius-sm);
    overflow: hidden;
    background: var(--surface-alt);
    flex-shrink: 0;
    block-size: 4rem;
    inline-size: 4rem;
  }

  :where(.media-content-editor-asset-card-thumb) > img {
    object-fit: cover;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.media-content-editor-asset-card-thumb.is-placeholder) {
    display: flex;
    color: var(--muted);
    justify-content: center;
    align-items:  center;
  }

  :where(.media-content-editor-asset-card-thumb.is-placeholder) > svg {
    block-size: 1.5rem;
    inline-size: 1.5rem;
  }

  :where(.media-content-editor-asset-card-thumb-fallback) {
    display: flex;
    color: var(--muted);
    justify-content: center;
    align-items:  center;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.media-content-editor-asset-card-thumb-fallback) > svg {
    block-size: 1.25rem;
    inline-size: 1.25rem;
  }

  :where(.media-content-editor-asset-card-skeleton) {
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.media-content-editor-asset-card-name-skeleton) {
    block-size: 1rem;
    inline-size: 12rem;
  }

  :where(.media-content-editor-asset-card-duration) {
    position: absolute;
    display: inline-flex;
    background: var(--scrim-strong);
    color: #fff;
    font-size: .625rem;
    line-height: 1.2;
    font-weight: var(--weight-medium);
    font-variant-numeric: tabular-nums;
    border-radius: .2rem;
    align-items:  center;
    padding-block-start: .05rem;
    padding-block-end: .05rem;
    padding-inline-start: .3rem;
    padding-inline-end: .3rem;
    bottom: .25rem;
    right: .25rem;
  }

  :where(.media-content-editor-asset-card-body) {
    display: flex;
    gap: var(--space-3xs);
    flex-direction: column;
    min-inline-size: 0;
  }

  :where(.media-content-editor-asset-card-name) {
    display: block;
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    color: var(--ink);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin: 0;
    line-height: 1.3;
  }

  :where(.media-content-editor-asset-card-meta) {
    display: flex;
    align-items:  center;
    gap: var(--space-2xs);
    font-size: var(--text-caption);
    color: var(--muted);
    flex-wrap: wrap;
    margin: 0;
    margin-block-start: var(--space-2xs);
  }

  :where(.media-content-editor-asset-card-empty-action) {
    grid-area: actions;
    display: inline-flex;
    color: var(--muted);
    justify-content: center;
    align-self:  center;
    align-items:  center;
    block-size: 2rem;
    inline-size: 2rem;
  }

  :where(.media-content-editor-asset-card-empty-action) > svg {
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(button.media-content-editor-asset-card.is-empty:hover) .media-content-editor-asset-card-empty-action {
    color: var(--ink);
  }

  :where(.media-content-editor-asset-card-actions) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-3xs);
  }

  :where(.media-content-editor-asset-card-actions) .button {
    color: var(--muted);
  }

  :where(.media-content-editor-asset-card-actions) .button:hover {
    color: var(--ink);
    background: var(--surface-alt);
  }

  :where(.media-content-editor-asset-card-actions) .button[aria-label^="Remove"]:hover {
    color: var(--danger);
    background: color-mix(in oklab, var(--danger) 10%, transparent);
  }

  :where(.media-content-editor-save-pill) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-2xs);
    font-size: var(--text-caption);
    color: var(--muted);
    font-weight: var(--weight-medium);
    opacity: 0;
    animation: media-editor-save-fade .2s var(--ease) forwards;
  }

  :where(.media-content-editor-save-pill) svg {
    block-size: .75rem;
    inline-size: .75rem;
  }

  :where(.media-content-editor-save-pill.is-saving) {
    color: var(--muted);
  }

  :where(.media-content-editor-save-pill.is-saved) {
    color: var(--positive);
  }

  @keyframes media-editor-save-fade {
    from {
      opacity: 0;
      transform: translateY(-2px);
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  :where(.command-palette-item-label) {
    font-weight: var(--weight-medium);
  }

  :where(.command-palette-item-description) {
    font-size: var(--text-caption);
    color: var(--muted);
  }

  :where(.command-palette-item[data-has-description] .command-palette-item-content) {
    display: flex;
    gap: calc(var(--space-xs) / 2);
    flex-direction: column;
    align-items:  flex-start;
  }

  :where(.edit-page) {
    display: flex;
    gap: var(--space-lg);
    flex-direction: column;
    block-size: 100%;
  }

  :where(.edit-page-header) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
  }

  :where(.edit-page-back) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-xs);
    padding: var(--space-xs) var(--space-sm);
    font-size: var(--text-ui);
    color: var(--muted);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--duration) var(--ease);
    background: none;
    border: none;
    inline-size: -moz-fit-content;
    inline-size: fit-content;
    margin-inline-start: calc(-1 * var(--space-sm));
  }

  :where(.edit-page-back):hover {
    color: var(--ink);
    background: var(--surface);
  }

  :where(.edit-page-back) svg {
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.edit-page-title-row) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.edit-page-title) {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    font-weight: var(--weight-bold);
    color: var(--ink);
    margin: 0;
  }

  :where(.edit-page-badges) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    margin-block-start: var(--space-xs);
  }

  :where(.edit-page-editor) {
    flex: 1;
    min-block-size: 0;
  }

  :where(.edit-page-loading) {
    display: flex;
    color: var(--muted);
    justify-content: center;
    align-items:  center;
    block-size: 100%;
  }

  :where(.media-picker) {
    --dialog-max-inline-size: 44rem;
    min-block-size: 70vh;
    max-block-size: 70vh;
  }

  :where(.media-picker-tabs) {
    display: flex;
    justify-content: center;
    padding-block-end: var(--space-xs);
  }

  :where(.media-picker-body) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.media-picker-search) {
    position: relative;
    display: flex;
    align-items:  center;
  }

  :where(.media-picker-search-icon) {
    position: absolute;
    left: var(--space-sm);
    color: var(--muted);
    pointer-events: none;
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.media-picker-search-input).input {
    inline-size: 100%;
    padding-inline-start: calc(var(--space-sm)  + 1rem + var(--space-xs));
  }

  :where(.media-picker-loading) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-xl);
    color: var(--muted);
    text-align: center;
    flex-direction: column;
    flex: 1;
  }

  :where(.media-picker-empty) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-xl);
    color: var(--muted);
    text-align: center;
    flex-direction: column;
    flex: 1;
  }

  :where(.media-picker-empty-icon) {
    color: var(--line);
    block-size: 3rem;
    inline-size: 3rem;
  }

  :where(.media-picker-empty-hint) {
    font-size: var(--text-ui);
    margin: 0;
  }

  :where(.media-picker-grid) {
    padding: var(--space-xs);
    align-items:  start;
  }

  :where(.media-picker-item) {
    display: flex;
    gap: var(--space-xs);
    padding: var(--space-xs);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--duration) var(--ease);
    background: none;
    flex-direction: column;
  }

  :where(.media-picker-item):hover {
    border-color: var(--accent);
    background: var(--surface);
  }

  :where(.media-picker-item):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.media-picker-item-thumb) {
    position: relative;
    aspect-ratio: 1;
    border-radius: var(--radius-sm);
    overflow: hidden;
    background: var(--surface-alt);
  }

  :where(.media-picker-item-thumb) img {
    object-fit: cover;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.media-picker-item-thumb--video) {
    aspect-ratio: 16 / 9;
  }

  :where(.media-picker-item-placeholder) {
    display: flex;
    color: var(--muted);
    justify-content: center;
    align-items:  center;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.media-picker-item-placeholder) svg {
    block-size: 1.5rem;
    inline-size: 1.5rem;
  }

  :where(.media-picker-item-badge) {
    position: absolute;
    top: var(--space-xs);
    right: var(--space-xs);
    display: flex;
    background: var(--paper);
    border-radius: var(--radius-sm);
    color: var(--accent);
    box-shadow: var(--shadow-sm);
    justify-content: center;
    align-items:  center;
    block-size: 1.25rem;
    inline-size: 1.25rem;
  }

  :where(.media-picker-item-badge) svg {
    block-size: .75rem;
    inline-size: .75rem;
  }

  :where(.media-picker-item-duration) {
    position: absolute;
    bottom: var(--space-xs);
    right: var(--space-xs);
    display: inline-flex;
    padding-inline: var(--space-xs);
    padding-block: calc(var(--space-3xs) / 2);
    background: var(--scrim-strong);
    color: #fff;
    font-size: var(--text-caption);
    font-variant-numeric: tabular-nums;
    border-radius: var(--radius-sm);
    align-items:  center;
  }

  :where(.media-picker-item-info) {
    display: flex;
    gap: calc(var(--space-xs) / 2);
    flex-direction: column;
    align-items:  flex-start;
  }

  :where(.media-picker-item-name) {
    font-size: var(--text-caption);
    font-weight: var(--weight-medium);
    color: var(--ink);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-inline-size: 100%;
  }

  :where(.media-picker-loadmore) {
    display: flex;
    justify-content: center;
    padding-block-start: var(--space-sm);
  }

  :where(.page-picker) {
    max-block-size: 80vh;
  }

  :where(.page-picker-content) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    padding-block-end: var(--space-md);
  }

  :where(.page-picker-search) {
    position: relative;
    display: flex;
    align-items:  center;
  }

  :where(.page-picker-search-icon) {
    position: absolute;
    left: var(--space-sm);
    color: var(--muted);
    pointer-events: none;
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.page-picker-search-input).input {
    inline-size: 100%;
    padding-inline-start: calc(var(--space-sm)  + 1rem + var(--space-xs));
  }

  :where(.page-picker-empty) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-xl);
    color: var(--muted);
    text-align: center;
    flex-direction: column;
  }

  :where(.page-picker-empty-icon) {
    color: var(--line);
    block-size: 3rem;
    inline-size: 3rem;
  }

  :where(.page-picker-empty-hint) {
    font-size: var(--text-ui);
    margin: 0;
  }

  :where(.page-picker-list) {
    list-style: none;
    display: flex;
    overflow-y: auto;
    flex-direction: column;
    max-block-size: 50vh;
    margin: 0;
    padding: 0;
  }

  :where(.page-picker-item) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding-inline-start: calc(var(--space-md)  + var(--depth, 0) * var(--space-md));
    padding-inline-end: var(--space-md);
    padding-block: var(--space-sm);
    text-align: start;
    border-radius: 0;
    justify-content: flex-start;
    font-weight: normal;
  }

  :where(.page-picker-item):hover {
    background: var(--surface-alt);
  }

  :where(.page-picker-item):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: -2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.page-picker-item-icon) {
    color: var(--muted);
    flex-shrink: 0;
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.page-picker-item-title) {
    font-size: var(--text-ui);
    color: var(--ink);
    flex-shrink: 0;
  }

  :where(.page-picker-item[data-no-title] .page-picker-item-title) {
    color: var(--muted);
    font-style: italic;
  }

  :where(.page-picker-item-path) {
    font-size: var(--text-caption);
    color: var(--muted);
    flex-shrink: 0;
  }

  :where(.metadata-panel) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.metadata-panel-empty) {
    padding: var(--space-lg);
    text-align: center;
    color: var(--muted);
  }

  :where(.metadata-panel-section) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
  }

  :where(.metadata-panel-section[data-width="half"]) {
    flex: 1;
    min-inline-size: 0;
  }

  :where(.metadata-panel-row) {
    display: flex;
    gap: var(--space-md);
  }

  :where(.metadata-panel-label) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    color: var(--muted);
  }

  :where(.metadata-panel-value) {
    font-size: var(--text-ui);
    color: var(--ink);
  }

  :where(.metadata-panel-input) {
    padding: var(--space-sm);
    font-size: var(--text-base);
    color: var(--ink);
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    transition: all var(--duration) var(--ease);
  }

  :where(.metadata-panel-input):focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--focus-ring);
  }

  :where(.metadata-panel-input)[data-error] {
    border-color: var(--danger);
  }

  :where(.metadata-panel-textarea) {
    padding: var(--space-sm);
    font-size: var(--text-base);
    color: var(--ink);
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    transition: all var(--duration) var(--ease);
  }

  :where(.metadata-panel-textarea):focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--focus-ring);
  }

  :where(.metadata-panel-textarea)[data-error] {
    border-color: var(--danger);
  }

  :where(.metadata-panel-textarea) {
    resize: vertical;
    min-block-size: 4rem;
  }

  :where(.metadata-panel-error) {
    font-size: var(--text-caption);
    color: var(--danger);
  }

  :where(.metadata-panel-hint) {
    font-size: var(--text-caption);
    color: var(--ink-muted);
    line-height: 1.4;
  }

  :where(.metadata-panel-slug-prefix) {
    font-size: var(--text-caption);
    color: var(--muted);
    font-family: var(--font-mono);
  }

  :where(.metadata-panel-checkbox-label) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-sm);
    font-size: var(--text-ui);
    color: var(--ink);
    cursor: pointer;
  }

  :where(.metadata-panel-select-wrapper) {
    position: relative;
  }

  :where(.metadata-panel-select) {
    padding: var(--space-sm);
    font-size: var(--text-base);
    color: var(--ink);
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    appearance: none;
    cursor: pointer;
    transition: all var(--duration) var(--ease);
    inline-size: 100%;
    padding-inline-end: var(--space-xl);
  }

  :where(.metadata-panel-select):focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--focus-ring);
  }

  :where(.metadata-panel-select-icon) {
    position: absolute;
    top: 50%;
    right: var(--space-sm);
    color: var(--muted);
    pointer-events: none;
    block-size: 1rem;
    inline-size: 1rem;
    transform: translateY(-50%);
  }

  :where(.metadata-panel-tags) {
    display: flex;
    gap: var(--space-xs);
    flex-wrap: wrap;
  }

  :where(.metadata-panel-tag) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-xs);
    padding: calc(var(--space-xs) / 2) var(--space-sm);
    font-size: var(--text-ui);
    color: var(--ink);
    background: var(--surface-alt);
    border-radius: var(--radius-sm);
  }

  :where(.metadata-panel-tag) button {
    display: inline-flex;
    color: var(--muted);
    cursor: pointer;
    transition: color var(--duration) var(--ease);
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
    padding: 0;
  }

  :where(.metadata-panel-tag) button:hover {
    color: var(--danger);
  }

  :where(.metadata-panel-tag) button svg {
    block-size: .75rem;
    inline-size: .75rem;
  }

  :where(.metadata-panel-tag-input) {
    display: flex;
    gap: var(--space-xs);
  }

  :where(.metadata-panel-tag-input) input {
    padding: var(--space-xs) var(--space-sm);
    font-size: var(--text-ui);
    color: var(--ink);
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    flex: 1;
  }

  :where(.metadata-panel-tag-input) input:focus {
    outline: none;
    border-color: var(--accent);
  }

  :where(.metadata-panel-tag-input) button {
    display: inline-flex;
    padding: var(--space-xs);
    background: var(--accent);
    color: var(--on-accent);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: opacity var(--duration) var(--ease);
    border: none;
    justify-content: center;
    align-items:  center;
  }

  :where(.metadata-panel-tag-input) button:disabled {
    opacity: .5;
    cursor: not-allowed;
  }

  :where(.metadata-panel-tag-input) button svg {
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.metadata-panel-featured-image) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.metadata-panel-featured-image-preview) {
    aspect-ratio: 16 / 9;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--surface-alt);
    max-block-size: 10rem;
  }

  :where(.metadata-panel-featured-image-preview) img {
    object-fit: cover;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.metadata-panel-featured-image-placeholder) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-xs);
    color: var(--muted);
    font-size: var(--text-caption);
    flex-direction: column;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.metadata-panel-featured-image-placeholder) svg {
    opacity: .5;
    block-size: 1.5rem;
    inline-size: 1.5rem;
  }

  :where(.metadata-panel-featured-image-placeholder) span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-inline-size: 80%;
  }

  :where(.metadata-panel-featured-image-actions) {
    display: flex;
    gap: var(--space-xs);
  }

  :where(.metadata-panel-featured-image-actions) button {
    padding: var(--space-xs) var(--space-sm);
    font-size: var(--text-ui);
    color: var(--ink);
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--duration) var(--ease);
  }

  :where(.metadata-panel-featured-image-actions) button:hover {
    border-color: var(--accent);
    background: var(--surface-alt);
  }

  :where(.metadata-panel-featured-image-add) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-xs);
    padding: var(--space-md);
    color: var(--muted);
    background: var(--surface);
    border: 1px dashed var(--line);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--duration) var(--ease);
  }

  :where(.metadata-panel-featured-image-add):hover:not(:disabled) {
    border-color: var(--accent);
    color: var(--ink);
    border-style: solid;
  }

  :where(.metadata-panel-featured-image-add):disabled {
    opacity: .5;
    cursor: not-allowed;
  }

  :where(.metadata-panel-featured-image-add) svg {
    block-size: 1.25rem;
    inline-size: 1.25rem;
  }

  :where(.page-organizer) {
    --dialog-max-inline-size: 36rem;
  }

  :where(.page-organizer-description) {
    font-size: var(--text-ui);
    color: var(--muted);
    margin: 0;
  }

  :where(.page-organizer-tree) {
    overflow-y: auto;
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--surface);
    max-block-size: 24rem;
  }

  :where(.page-organizer-tree)[data-processing] {
    opacity: .6;
    pointer-events: none;
  }

  :where(.page-organizer-root) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    padding: var(--space-sm) var(--space-md);
    border-block-end: 1px solid var(--line);
    background: var(--surface-alt);
    transition: background var(--duration) var(--ease);
  }

  :where(.page-organizer-root)[data-drop-inside] {
    background: color-mix(in oklab, var(--accent) 15%, var(--surface));
  }

  :where(.page-organizer-list) {
    display: flex;
    flex-direction: column;
  }

  :where(.page-organizer-row) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    padding: var(--space-sm) var(--space-md);
    transition: background var(--duration) var(--ease), opacity var(--duration) var(--ease);
  }

  :where(.page-organizer-row):hover {
    background: var(--surface-alt);
  }

  :where(.page-organizer-row)[data-ghost] {
    opacity: .4;
  }

  :where(.page-organizer-row)[data-clone] {
    background: var(--paper);
    border: 1px solid var(--accent);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
  }

  :where(.page-organizer-handle) {
    display: flex;
    border-radius: var(--radius-sm);
    cursor: grab;
    color: var(--muted);
    transition: all var(--duration) var(--ease);
    touch-action: none;
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
    block-size: 1.25rem;
    inline-size: 1.25rem;
    padding: 0;
  }

  :where(.page-organizer-handle):hover {
    background: var(--surface-alt);
    color: var(--ink);
  }

  :where(.page-organizer-handle):active {
    cursor: grabbing;
  }

  :where(.page-organizer-handle) svg {
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.page-organizer-toggle) {
    display: flex;
    border-radius: var(--radius-sm);
    cursor: pointer;
    color: var(--muted);
    transition: all var(--duration) var(--ease);
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
    block-size: 1.25rem;
    inline-size: 1.25rem;
    padding: 0;
  }

  :where(.page-organizer-toggle):hover {
    background: var(--surface-alt);
    color: var(--ink);
  }

  :where(.page-organizer-toggle-spacer) {
    display: block;
    block-size: 1.25rem;
    inline-size: 1.25rem;
  }

  :where(.page-organizer-chevron) {
    transition: transform var(--duration) var(--ease);
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.page-organizer-chevron)[data-expanded] {
    transform: rotate(90deg);
  }

  :where(.page-organizer-icon) {
    color: var(--muted);
    flex-shrink: 0;
    block-size: 1rem;
    inline-size: 1rem;
  }

  :where(.page-organizer-title) {
    font-size: var(--text-ui);
    color: var(--ink);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
  }

  :where(.page-organizer-count) {
    display: flex;
    padding-inline: calc(var(--space-xs) / 2);
    font-size: var(--text-caption);
    font-weight: var(--weight-medium);
    color: var(--paper);
    background: var(--accent);
    border-radius: var(--radius-full);
    justify-content: center;
    align-items:  center;
    block-size: 1.25rem;
    min-inline-size: 1.25rem;
  }

  :where(.access-picker) {
    position: relative;
    display: inline-flex;
    border: none;
    flex-shrink: 0;
    align-items:  center;
    min-inline-size: 0;
    margin-inline-start: auto;
    padding: 0;
  }

  :where(.access-picker)[data-disabled] {
    opacity: .5;
    pointer-events: none;
  }

  :where(.access-picker-badge) {
    font: inherit;
    display: flex;
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--duration) var(--ease);
    border: none;
    justify-content: center;
    align-items:  center;
    block-size: 1.25rem;
    inline-size: 1.25rem;
    padding: 0;
  }

  :where(.access-picker-badge):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.access-picker-badge)[data-access="inherit"] {
    background: var(--surface-alt);
    color: var(--muted);
  }

  :where(.access-picker-badge)[data-access="public"] {
    background: color-mix(in oklab, var(--positive) 20%, var(--surface));
    color: var(--positive);
  }

  :where(.access-picker-badge)[data-access="auth"] {
    background: color-mix(in oklab, var(--warning) 20%, var(--surface));
    color: var(--warning);
  }

  :where(.access-picker-badge)[data-access="membership"] {
    background: color-mix(in oklab, var(--danger) 20%, var(--surface));
    color: var(--danger);
  }

  :where(.access-picker-badge)[data-inherited] {
    opacity: .8;
    border: 1px dashed;
  }

  :where(.access-picker-options) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
  }

  :where(.access-picker-option) {
    display: flex;
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--duration) var(--ease);
    border: none;
    justify-content: center;
    align-items:  center;
    block-size: 1.25rem;
    inline-size: 1.25rem;
  }

  :where(.access-picker-option)[data-access="inherit"] {
    background: var(--surface-alt);
    color: var(--muted);
  }

  :where(.access-picker-option)[data-access="inherit"]:hover {
    background: var(--surface);
    color: var(--ink);
  }

  :where(.access-picker-option)[data-access="public"] {
    background: color-mix(in oklab, var(--positive) 15%, var(--surface));
    color: var(--positive);
  }

  :where(.access-picker-option)[data-access="public"]:hover {
    background: color-mix(in oklab, var(--positive) 25%, var(--surface));
  }

  :where(.access-picker-option)[data-access="auth"] {
    background: color-mix(in oklab, var(--warning) 15%, var(--surface));
    color: var(--warning);
  }

  :where(.access-picker-option)[data-access="auth"]:hover {
    background: color-mix(in oklab, var(--warning) 25%, var(--surface));
  }

  :where(.access-picker-option)[data-access="membership"] {
    background: color-mix(in oklab, var(--danger) 15%, var(--surface));
    color: var(--danger);
  }

  :where(.access-picker-option)[data-access="membership"]:hover {
    background: color-mix(in oklab, var(--danger) 25%, var(--surface));
  }

  :where(.access-picker-option)[data-selected] {
    box-shadow: 0 0 0 2px;
  }

  :where(.access-picker-option):has(input:focus-visible) {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.metadata-dialog .metadata-panel) {
    overflow-y: auto;
    max-block-size: 60vh;
  }

  :where(.version-history-dialog) {
    --dialog-max-inline-size: 56rem;
    min-block-size: min(60vh, calc(100dvh - var(--space-lg) * 2));
    overflow-y: hidden;
  }

  :where(.version-history-dialog-layout) {
    display: grid;
    grid-template-columns: 16rem 1fr;
    flex: 1;
    min-block-size: 0;
  }

  @container dialog (inline-size <= 34rem) {
    :where(.version-history-dialog-layout) {
      grid-template-columns: 1fr;
      grid-template-rows: auto 1fr;
    }
  }

  :where(.version-history-dialog-preview) {
    position: relative;
    padding: var(--space-md);
    overflow-y: auto;
    transition: opacity var(--duration) var(--ease);
    background: none;
  }

  :where(.version-history-dialog-preview)[data-loading="true"] {
    opacity: 0;
    pointer-events: none;
  }

  :where(.version-history-dialog-preview-empty) {
    display: flex;
    color: var(--muted);
    font-size: var(--text-ui);
    justify-content: center;
    align-items:  center;
    block-size: 100%;
  }

  :where(.version-history-dialog-preview-error) {
    display: flex;
    color: var(--danger);
    font-size: var(--text-ui);
    justify-content: center;
    align-items:  center;
    block-size: 100%;
  }

  :where(.version-history-dialog-preview-raw) {
    font-family: var(--font-mono);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    white-space: pre-wrap;
    word-break: break-word;
    margin: 0;
  }

  :where(.version-history-dialog-versions) {
    display: flex;
    gap: var(--space-xs);
    padding: var(--space-md);
    flex-direction: column;
    padding-block-end: var(--space-lg);
  }

  @container dialog (inline-size <= 34rem) {
    :where(.version-history-dialog-versions) {
      max-block-size: 10rem;
    }
  }

  :where(.version-history-dialog-card) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    cursor: pointer;
    text-align: start;
    transition: all var(--duration) var(--ease);
  }

  :where(.version-history-dialog-card):hover:not([data-selected]) {
    border-color: var(--accent);
    background: var(--surface-alt);
  }

  :where(.version-history-dialog-card)[data-selected] {
    border-color: var(--accent);
    background: color-mix(in oklab, var(--accent) 10%, var(--surface));
    box-shadow: 0 0 0 2px color-mix(in oklab, var(--accent) 25%, transparent);
  }

  :where(.version-history-dialog-card):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.version-history-dialog-card-time) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    color: var(--ink);
  }

  :where(.version-history-dialog-empty) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-xl);
    color: var(--muted);
    text-align: center;
    flex-direction: column;
    block-size: 100%;
  }

  :where(.version-history-dialog-empty) p {
    margin: 0;
  }

  :where(.version-history-dialog-empty-hint) {
    font-size: var(--text-ui);
    opacity: .75;
  }

  :where(.version-history-dialog-checkpoint) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-xs);
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-ui);
    color: var(--muted);
    border: 1px dashed var(--line);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--duration) var(--ease);
    background: none;
    margin-block-start: var(--space-sm);
  }

  :where(.version-history-dialog-checkpoint):hover:not(:disabled) {
    color: var(--ink);
    border-color: var(--accent);
    border-style: solid;
  }

  :where(.version-history-dialog-checkpoint):disabled {
    opacity: .5;
    cursor: not-allowed;
  }
}

/* packages/ui/src/styles/blocks/pagination.css */
@layer components {
  :where(.pagination) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-md);
    padding-block-start: var(--space-lg);
  }

  :where(.pagination) [aria-disabled="true"] {
    pointer-events: none;
  }

  :where(.pagination-info) {
    font-size: var(--text-ui);
    color: var(--muted);
    text-align: center;
    min-inline-size: 6rem;
  }
}

/* packages/ui/src/styles/blocks/filter-bar.css */
@layer components {
  :where(.filter-bar) {
    display: flex;
    flex-wrap: wrap;
    align-items:  center;
    gap: .382em;
  }

  :where(.filter-bar-chip) {
    display: inline-flex;
    border: 1px solid var(--line);
    border-radius: var(--radius-full);
    color: var(--muted);
    font: inherit;
    font-size: var(--text-caption);
    cursor: pointer;
    transition: background-color var(--duration) var(--ease), border-color var(--duration) var(--ease), color var(--duration) var(--ease);
    background: none;
    align-items:  center;
    gap: .382em;
    padding: .382em .618em;
  }

  .filter-bar-chip:hover {
    background: var(--surface-alt);
    color: var(--ink);
  }

  .filter-bar-chip[data-active] {
    background: var(--accent-subtle);
    border-color: var(--accent);
    color: var(--accent);
  }

  .filter-bar-chip-label {
    white-space: nowrap;
    font-weight: var(--weight-medium);
  }

  .filter-bar-chip[data-active] .filter-bar-chip-label {
    color: color-mix(in oklab, currentColor 82%, var(--ink));
  }

  .filter-bar-chip-separator {
    white-space: nowrap;
    color: color-mix(in oklab, currentColor 72%, var(--ink));
  }

  .filter-bar-chip-value {
    font-weight: var(--weight-semibold);
    white-space: nowrap;
    color: currentColor;
  }

  .filter-bar-chip-chevron {
    opacity: .5;
    flex-shrink: 0;
  }

  .filter-bar-chip:hover .filter-bar-chip-chevron, .filter-bar-chip[data-active] .filter-bar-chip-chevron {
    opacity: 1;
  }

  .filter-bar-chip-count {
    display: inline-flex;
    padding-inline: var(--space-xs);
    background: var(--accent);
    color: var(--paper);
    border-radius: var(--radius-full);
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    font-variant-numeric: tabular-nums;
    justify-content: center;
    align-items:  center;
    block-size: 1.25rem;
    min-inline-size: 1.25rem;
  }

  :where(.filter-bar-search) {
    position: relative;
    display: flex;
    flex: 10rem;
    align-items:  center;
    min-inline-size: 0;
  }

  .filter-bar-search-icon {
    position: absolute;
    color: var(--muted);
    pointer-events: none;
    left: .618em;
  }

  .filter-bar-search-input {
    border-radius: var(--radius-full);
    color: inherit;
    font: inherit;
    font-size: var(--text-caption);
    outline: none;
    transition: background-color var(--duration) var(--ease), border-color var(--duration) var(--ease);
    background: none;
    border: 1px solid #0000;
    inline-size: 100%;
    padding: .382em .618em .382em calc(.618em + 1.25rem);
  }

  .filter-bar-search-input::placeholder {
    color: var(--muted);
  }

  .filter-bar-search-input:hover {
    background: var(--surface-alt);
  }

  .filter-bar-search-input:focus-visible {
    border-color: var(--accent);
    background: var(--surface-alt);
  }

  .filter-bar-search-input::-webkit-search-cancel-button {
    display: none;
  }

  :where(.filter-bar-month-nav) {
    display: inline-flex;
    border: 1px solid var(--line);
    border-radius: var(--radius-full);
    font-size: var(--text-caption);
    align-items:  center;
    gap: 0;
  }

  .filter-bar-month-btn {
    display: inline-flex;
    border-radius: var(--radius-full);
    color: var(--muted);
    cursor: pointer;
    transition: background-color var(--duration) var(--ease), color var(--duration) var(--ease);
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
    padding: .382em;
  }

  .filter-bar-month-btn:hover:not(:disabled) {
    background: var(--surface-alt);
    color: var(--ink);
  }

  .filter-bar-month-btn:disabled {
    opacity: .3;
    cursor: default;
  }

  .filter-bar-month-label {
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
    text-align: center;
    min-inline-size: 7em;
    padding-inline-start: .236em;
    padding-inline-end: .236em;
  }

  :where(.filter-bar-clear) {
    display: inline-flex;
    border-radius: var(--radius-full);
    color: var(--muted);
    font: inherit;
    font-size: var(--text-caption);
    cursor: pointer;
    transition: background-color var(--duration) var(--ease), color var(--duration) var(--ease);
    background: none;
    border: none;
    align-items:  center;
    gap: .236em;
    padding: .382em .618em;
  }

  .filter-bar-clear:hover {
    background: var(--surface-alt);
    color: var(--ink);
  }
}

/* packages/ui/src/styles/blocks/filter-chip.css */
@layer components {
  :where(.filter-chip) {
    display: inline-flex;
    border: 1px solid var(--line);
    border-radius: var(--radius-full);
    font: inherit;
    font-size: var(--text-caption);
    cursor: pointer;
    transition: background-color var(--duration) var(--ease), border-color var(--duration) var(--ease);
    background: none;
    align-items:  center;
    gap: .382em;
    padding: .382em .618em;
  }

  .filter-chip:hover {
    background: var(--surface-alt);
  }

  .filter-chip[data-selected] {
    background: var(--accent-subtle);
    border-color: var(--accent);
    color: var(--accent);
  }

  .filter-chip-label {
    white-space: nowrap;
  }

  .filter-chip-count {
    font-variant-numeric: tabular-nums;
    opacity: .7;
  }

  .filter-chip[data-selected] .filter-chip-count {
    opacity: 1;
  }
}

/* packages/ui/src/styles/blocks/batch-action-bar.css */
@layer components {
  :where(.batch-action-bar) {
    position: fixed;
    bottom: var(--space-xl);
    z-index: var(--z-overlay);
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-lg);
    left: 50%;
    translate: -50%;
  }

  :where(.batch-action-bar-count) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    white-space: nowrap;
    padding-inline: var(--space-xs);
  }

  :where(.batch-action-bar-divider) {
    background: var(--line);
    flex-shrink: 0;
    block-size: 1.25rem;
    inline-size: 1px;
  }
}

/* packages/ui/src/styles/blocks/audio-player.css */
@layer components {
  :where(.audio-player) {
    --surface-radius: var(--radius-md);
    --card-padding: var(--space-xs) var(--space-sm);
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    box-sizing: border-box;
    inline-size: 100%;
  }

  :where(.audio-player-play) {
    flex-shrink: 0;
  }

  :where(.audio-player-progress) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    flex: 1;
    min-inline-size: 0;
  }

  :where(.audio-player-time) {
    font-size: var(--text-caption);
    color: var(--muted);
    font-variant-numeric: tabular-nums;
    display: flex;
    flex-shrink: 0;
    justify-content: flex-start;
    align-items:  center;
    inline-size: 2rem;
    line-height: 1;
  }

  :where(.audio-player-scrubber) {
    appearance: none;
    -webkit-appearance: none;
    margin-block: var(--space-xs);
    border-radius: var(--radius-full);
    background: linear-gradient(to right, var(--accent) var(--progress, 0%), var(--line) var(--progress, 0%));
    cursor: pointer;
    outline: none;
    flex: 1;
    block-size: .25rem;
    inline-size: 100%;
  }

  :where(.audio-player-scrubber)::-webkit-slider-thumb {
    appearance: none;
    -webkit-appearance: none;
    background: var(--accent);
    cursor: pointer;
    opacity: 0;
    transition: opacity var(--duration) var(--ease), transform var(--duration) var(--ease);
    border-radius: 50%;
    block-size: .75rem;
    inline-size: .75rem;
  }

  :where(.audio-player-scrubber)::-moz-range-thumb {
    background: var(--accent);
    cursor: pointer;
    opacity: 0;
    transition: opacity var(--duration) var(--ease);
    border: none;
    border-radius: 50%;
    block-size: .75rem;
    inline-size: .75rem;
  }

  :where(.audio-player-scrubber):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.audio-player):hover :where(.audio-player-scrubber)::-webkit-slider-thumb {
    opacity: 1;
  }

  :where(.audio-player-scrubber):focus-visible::-webkit-slider-thumb {
    opacity: 1;
  }

  :where(.audio-player):hover :where(.audio-player-scrubber)::-moz-range-thumb {
    opacity: 1;
  }

  :where(.audio-player-scrubber):focus-visible::-moz-range-thumb {
    opacity: 1;
  }

  :where(.audio-player):hover :where(.audio-player-scrubber):hover::-webkit-slider-thumb {
    transform: scale(1.2);
  }

  :where(.audio-player-speed-btn) {
    font-variant-numeric: tabular-nums;
  }

  :where(.audio-player-sep) {
    display: block;
    block-size: var(--space-md);
    background: var(--line);
    flex-shrink: 0;
    inline-size: 1px;
  }
}

/* packages/ui/src/styles/blocks/logs-display.css */
@layer components {
  :where(.logs-display) {
    padding: var(--space-sm);
    background: color-mix(in oklab, var(--surface) 92%, transparent);
    border-radius: var(--radius-md);
    overflow-y: auto;
    font-family: var(--font-mono);
    font-size: var(--text-caption);
    max-block-size: min(60vh, 28rem);
  }

  .logs-display-line {
    display: grid;
    grid-template-columns: auto auto 1fr;
    gap: var(--space-sm);
    padding-block: var(--space-xs);
    white-space: nowrap;
  }

  .logs-display-timestamp {
    color: var(--muted);
  }

  .logs-display-level {
    text-transform: uppercase;
    font-weight: var(--weight-semibold);
  }

  .logs-display-level[data-level="info"] {
    color: var(--accent);
  }

  .logs-display-level[data-level="warn"] {
    color: var(--warning);
  }

  .logs-display-level[data-level="error"] {
    color: var(--danger);
  }

  .logs-display-level[data-level="debug"] {
    color: color-mix(in oklab, var(--accent) 75%, var(--muted) 25%);
  }

  .logs-display-message {
    color: var(--ink);
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .logs-display-placeholder {
    color: var(--muted);
    font-size: var(--text-ui);
  }
}

/* packages/ui/src/styles/blocks/json-tree-view.css */
@layer components {
  :where(.json-tree) {
    position: relative;
    font-family: var(--font-mono);
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
  }

  .json-tree-copy {
    position: absolute;
    opacity: .5;
    transition: opacity var(--duration) var(--ease);
    top: 0;
    right: 0;
  }

  .json-tree:hover .json-tree-copy {
    opacity: 1;
  }

  .json-tree-toggle {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-2xs);
    font: inherit;
    cursor: pointer;
    color: inherit;
    background: none;
    border: none;
    padding: 0;
  }

  .json-tree-toggle:hover {
    color: var(--accent);
  }

  .json-tree-children {
    border-inline-start: 1px solid var(--line);
    margin-inline-start: var(--space-sm);
    padding-inline-start: var(--space-md);
  }

  .json-tree-entry {
    display: block;
  }

  .json-key {
    color: var(--accent);
  }

  .json-colon {
    color: var(--muted);
  }

  .json-string {
    color: var(--positive);
  }

  .json-number {
    color: var(--warning);
  }

  .json-boolean {
    color: var(--accent);
  }

  .json-null {
    color: var(--muted);
    font-style: italic;
  }

  .json-brackets {
    color: var(--muted);
  }

  .json-preview {
    color: var(--muted);
    margin-inline: var(--space-2xs);
    font-style: italic;
  }
}

/* packages/ui/src/styles/blocks/demo.css */
@layer components {
  :where(.page) {
    display: flex;
    gap: var(--space-lg);
    flex-direction: column;
    margin-block-end: var(--space-lg);
  }

  :where(.permission-loading) {
    align-items:  center;
  }

  :where(.page-header) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.page-title) {
    font-size: var(--text-4xl);
    line-height: 2.5rem;
    font-weight: var(--weight-bold);
    letter-spacing: -.03em;
  }

  :where(.page-subtitle) {
    font-size: var(--text-lg);
    color: var(--muted);
    max-width: 42rem;
  }

  :where(.page-actions) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.inline-code) {
    background-color: var(--surface-alt);
    padding: var(--space-2xs) var(--space-xs);
    border-radius: var(--radius-sm);
    font-size: var(--text-ui);
  }

  :where(.counter-card) {
    background: linear-gradient(135deg, color-mix(in oklab, var(--surface-alt) 60%, transparent), transparent);
  }

  :where(.counter-content) {
    display: grid;
    gap: var(--space-md);
  }

  :where(.counter-display) {
    font-size: var(--text-4xl);
    font-weight: var(--weight-bold);
    letter-spacing: -.02em;
  }

  .counter-display[data-loading] {
    color: var(--muted);
  }

  :where(.counter-actions) {
    display: flex;
    gap: var(--space-sm);
  }

  :where(.mono-list) {
    display: grid;
    gap: var(--space-md);
  }

  :where(.mono-item) {
    border-radius: var(--radius-lg);
    border: 1px solid var(--line);
    padding: var(--space-md);
    display: grid;
    gap: var(--space-sm);
    background: var(--surface);
  }

  :where(.mono-key) {
    font-size: var(--text-ui);
    font-weight: var(--weight-semibold);
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--muted);
  }

  :where(.mono-code) {
    font-size: var(--text-ui);
    white-space: pre-wrap;
    color: var(--ink);
    background: var(--surface-alt);
    padding: var(--space-sm);
    border-radius: var(--radius-md);
    margin: 0;
  }

  :where(.mono-kv) {
    display: grid;
    gap: var(--space-sm);
    margin: 0;
  }

  :where(.mono-kv-row) {
    display: grid;
    gap: var(--space-2xs);
  }

  :where(.mono-kv-key) {
    font-size: var(--text-caption);
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--muted);
  }

  :where(.mono-kv-value) {
    font-size: var(--text-base);
    margin: 0;
  }

  :where(.mono-empty) {
    color: var(--muted);
    font-size: var(--text-base);
  }

  :where(.mono-loading) {
    color: var(--muted);
    font-size: var(--text-base);
  }
}

/* packages/ui/src/styles/blocks/feedback.css */
@layer components {
  :where(.feedback-dialog-body) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.feedback-textarea) {
    padding: var(--space-sm);
    font-family: inherit;
    font-size: var(--text-ui);
    line-height: var(--leading-normal);
    color: var(--ink);
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    resize: vertical;
    transition: border-color var(--duration);
    min-block-size: 6.25rem;
    inline-size: 100%;
  }

  :where(.feedback-textarea):focus {
    outline: none;
    border-color: var(--accent);
  }

  :where(.feedback-textarea)::placeholder {
    color: var(--muted);
  }

  :where(.feedback-textarea):disabled {
    opacity: .6;
    cursor: not-allowed;
  }

  :where(.feedback-error) {
    color: var(--danger);
    font-size: var(--text-ui);
    margin: 0;
  }

  :where(.feedback-metadata-trigger) {
    font-size: var(--text-ui);
    color: var(--muted);
  }

  :where(.feedback-metadata-trigger):hover {
    color: var(--ink);
  }

  :where(.feedback-metadata-list) {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: var(--space-2xs) var(--space-sm);
    font-size: var(--text-ui);
    margin-block-start: var(--space-xs);
  }

  :where(.feedback-screenshot-preview) {
    position: relative;
    display: inline-block;
    margin-block-start: var(--space-xs);
  }

  :where(.feedback-screenshot-thumbnail) {
    border-radius: var(--radius-md);
    border: 1px solid var(--line);
    object-fit: cover;
    object-position: top left;
    display: block;
    block-size: 6rem;
    inline-size: 6rem;
  }

  :where(.feedback-screenshot-remove) {
    all: unset;
    position: absolute;
    top: var(--space-2xs);
    right: var(--space-2xs);
    display: flex;
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--muted);
    cursor: pointer;
    opacity: 0;
    transition: opacity var(--duration) var(--ease), color var(--duration) var(--ease);
    justify-content: center;
    align-items:  center;
    block-size: 1.5rem;
    inline-size: 1.5rem;
  }

  .feedback-screenshot-preview:hover :where(.feedback-screenshot-remove) {
    opacity: 1;
  }

  :where(.feedback-screenshot-remove):hover {
    color: var(--danger);
  }

  :where(.feedback-metadata-row) {
    display: contents;
  }

  :where(.feedback-metadata-row) dt {
    color: var(--muted);
  }

  :where(.feedback-metadata-row) dd {
    color: var(--ink);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin: 0;
  }
}

/* packages/ui/src/styles/blocks/stat-card.css */
@layer components {
  :where(.stat-card-grid) {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-md);
  }

  :where(.stat-card-grid)[data-cols="2"] {
    grid-template-columns: repeat(2, 1fr);
  }

  :where(.stat-card) {
    --card-padding: var(--space-md);
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.stat-card)[data-loading] {
    opacity: .6;
  }

  :where(.stat-card-header) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
  }

  :where(.stat-card-actions) {
    display: flex;
    align-items:  center;
    gap: var(--space-3xs);
    margin-inline-start: auto;
  }

  :where(.stat-card-icon) {
    display: flex;
    opacity: .8;
    align-items:  center;
  }

  :where(.stat-card-label) {
    font-size: var(--text-ui);
    color: var(--muted);
    font-weight: var(--weight-medium);
  }

  :where(.stat-card-body) {
    display: flex;
    justify-content: space-between;
    align-items:  flex-end;
    gap: var(--space-md);
  }

  :where(.stat-card-metric) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
  }

  :where(.stat-card-value) {
    font-size: var(--text-4xl);
    font-weight: var(--weight-bold);
    letter-spacing: -.02em;
    line-height: 1;
  }

  :where(.stat-card)[data-size="sm"] {
    --card-padding: var(--space-sm);
    gap: var(--space-xs);
  }

  :where(.stat-card)[data-size="sm"] :where(.stat-card-value) {
    font-size: var(--text-xl);
  }

  :where(.stat-card-description) {
    font-size: var(--text-caption);
    color: var(--muted);
  }

  :where(.stat-card-grid)[data-compact] :where(.stat-card-value) {
    font-size: var(--text-2xl);
  }

  :where(.stat-card-sparkline) {
    block-size: var(--space-lg);
    container-type: inline-size;
    flex: 1;
    min-inline-size: 0;
  }

  @media (max-width: 64rem) {
    :where(.stat-card-grid) {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  @media (max-width: 40rem) {
    :where(.stat-card-grid) {
      grid-template-columns: 1fr;
    }

    :where(.stat-card-grid)[data-cols="2"] {
      grid-template-columns: 1fr;
    }

    :where(.stat-card-value) {
      font-size: var(--text-3xl);
    }
  }
}

/* packages/ui/src/styles/blocks/trend-badge.css */
@layer components {
  :where(.trend-badge) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-xs);
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-full);
  }

  .trend-badge[data-trend="up"] {
    color: var(--positive);
    background: color-mix(in oklab, var(--positive) 15%, transparent);
  }

  .trend-badge[data-trend="down"] {
    color: var(--danger);
    background: color-mix(in oklab, var(--danger) 15%, transparent);
  }

  .trend-badge[data-trend="neutral"] {
    color: var(--muted);
    background: color-mix(in oklab, var(--muted) 15%, transparent);
  }

  .trend-badge-icon {
    width: var(--text-ui);
    height: var(--text-ui);
    flex-shrink: 0;
  }

  .trend-badge-value {
    white-space: nowrap;
  }
}

/* packages/ui/src/styles/blocks/bar-list.css */
@layer components {
  :where(.bar-list) {
    display: flex;
    gap: var(--space-3xs);
    flex-direction: column;
  }

  :where(.bar-list-item) {
    position: relative;
    isolation: isolate;
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-2xs) var(--space-sm);
    border-radius: var(--radius-sm);
    transition: background-color .12s;
  }

  :where(.bar-list-item):before {
    content: "";
    position: absolute;
    width: var(--bar-width, 0%);
    background: color-mix(in oklab, var(--bar-color, var(--accent)) 18%, transparent);
    border-radius: inherit;
    z-index: -1;
    transition: width .32s cubic-bezier(.2,.7,.2,1);
    inset: 0;
  }

  :where(.bar-list-item:hover):before {
    background: color-mix(in oklab, var(--bar-color, var(--accent)) 28%, transparent);
  }

  :where(.bar-list-label) {
    font-size: var(--text-ui);
    flex: 1;
    min-width: 0;
  }

  :where(.bar-list-value) {
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    font-variant-numeric: tabular-nums;
    color: var(--ink-muted);
    white-space: nowrap;
  }

  :where(.bar-list-empty) {
    color: var(--muted);
    font-size: var(--text-ui);
    padding: var(--space-md);
    text-align: center;
  }
}

/* packages/ui/src/styles/blocks/dashboard.css */
@layer components {
  :where(.dashboard) {
    padding: var(--space-lg);
    display: flex;
    gap: var(--space-lg);
    flex-direction: column;
    inline-size: 100%;
    max-inline-size: 75rem;
    margin: 0 auto;
  }

  :where(.dashboard[data-wide]) {
    max-inline-size: none;
  }

  :where(.dashboard-header) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-md);
    flex-wrap: wrap;
  }

  :where(.dashboard-title) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
  }

  :where(.dashboard-title-icon) {
    opacity: .6;
  }

  :where(.dashboard-title-h1) {
    font-size: var(--text-3xl);
    font-weight: var(--weight-bold);
    letter-spacing: -.02em;
    margin: 0;
  }

  :where(.dashboard-chart) {
    inline-size: 100%;
  }

  :where(.dashboard-charts-row) {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
  }

  :where(.dashboard-chart)[data-half] {
    min-inline-size: 0;
  }

  :where(.dashboard-panels) {
    display: grid;
    gap: var(--space-md);
  }

  :where(.dashboard-panels)[data-cols="2"] {
    grid-template-columns: repeat(2, 1fr);
  }

  :where(.dashboard-empty) {
    color: var(--muted);
    font-size: var(--text-ui);
    padding: var(--space-lg);
    text-align: center;
  }

  :where(.dashboard-actions) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
  }

  :where(.dashboard-toggle) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    font-size: var(--text-ui);
    cursor: pointer;
    user-select: none;
  }

  :where(.dashboard-toggle) [type="checkbox"] {
    cursor: pointer;
    accent-color: var(--accent);
  }

  :where(.dashboard-loading) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-md);
    padding: var(--space-xl);
    color: var(--muted);
    font-size: var(--text-ui);
    flex-direction: column;
  }

  @media (max-width: 64rem) {
    .dashboard-charts-row, .dashboard-panels[data-cols="2"] {
      grid-template-columns: 1fr;
    }
  }

  @media (max-width: 40rem) {
    .dashboard {
      padding: var(--space-md);
    }

    .dashboard-header {
      flex-direction: column;
      align-items:  flex-start;
    }
  }
}

/* packages/ui/src/styles/blocks/date-picker.css */
@keyframes date-picker-in {
  from {
    opacity: 0;
    transform: scale(.95) translateY(calc(var(--space-sm) * -1));
  }

  to {
    opacity: 1;
    transform: scale(1)translateY(0);
  }
}

@keyframes date-picker-out {
  from {
    opacity: 1;
    transform: scale(1)translateY(0);
  }

  to {
    opacity: 0;
    transform: scale(.95) translateY(calc(var(--space-sm) * -1));
  }
}

@layer components {
  :where(.date-picker) {
    position: relative;
    display: inline-flex;
  }

  :where(.date-picker-trigger) {
    display: inline-flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--date-picker-trigger-gap, var(--space-sm));
    min-inline-size: var(--date-picker-trigger-min-inline-size, 10rem);
    min-block-size: var(--date-picker-trigger-size, var(--input-size, var(--control-md)));
    padding-block: var(--date-picker-trigger-py, var(--input-py, var(--space-xs)));
    padding-inline: var(--date-picker-trigger-px, var(--input-px, var(--space-sm)));
    background: var(--date-picker-trigger-bg, var(--input-bg, var(--paper)));
    border: 1px solid var(--date-picker-trigger-border, var(--input-border, var(--line)));
    border-radius: var(--date-picker-trigger-radius, var(--input-radius, var(--radius-md)));
    font-size: var(--date-picker-trigger-font-size, var(--input-font-size, var(--text-ui)));
    color: var(--date-picker-trigger-fg, var(--input-fg, var(--ink)));
    cursor: pointer;
    user-select: none;
    line-height: var(--leading-normal);
    transition: border-color var(--duration) var(--ease), box-shadow var(--duration) var(--ease), background var(--duration) var(--ease);
  }

  :where(.date-picker-trigger):hover:not([aria-disabled]) {
    border-color: var(--date-picker-trigger-border-hover, var(--input-border-hover, var(--accent)));
  }

  :where(.date-picker-trigger):focus-visible {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--focus-ring);
  }

  :where(.date-picker-trigger)[aria-invalid="true"] {
    border-color: var(--danger);
  }

  :where(.date-picker-trigger)[aria-invalid="true"]:focus-visible {
    box-shadow: 0 0 0 3px var(--focus-ring-danger);
  }

  :where(.date-picker-trigger)[data-placeholder] {
    color: var(--muted);
  }

  :where(.date-picker-trigger)[aria-disabled] {
    opacity: .5;
    pointer-events: none;
  }

  :where(.date-picker-value) {
    text-align: start;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
  }

  :where(.date-picker-trigger-icon) {
    inline-size: var(--space-md);
    block-size: var(--space-md);
    color: var(--muted);
    flex-shrink: 0;
  }

  :where(.date-picker[data-has-clear] .date-picker-trigger-icon) {
    visibility: hidden;
  }

  :where(.date-picker-clear) {
    position: absolute;
    display: inline-flex;
    inline-size: var(--space-md);
    block-size: var(--space-md);
    border-radius: var(--radius-sm);
    color: var(--muted);
    cursor: pointer;
    transition: color var(--duration) var(--ease), background var(--duration) var(--ease);
    background: none;
    border: 0;
    justify-content: center;
    align-items:  center;
    padding: 0;
    top: 50%;
    transform: translateY(-50%);
  }

  :where(.date-picker-clear):not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: var(--date-picker-trigger-px, var(--input-px, var(--space-sm)));
  }

  :where(.date-picker-clear):not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: var(--date-picker-trigger-px, var(--input-px, var(--space-sm)));
  }

  :where(.date-picker-clear):not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: var(--date-picker-trigger-px, var(--input-px, var(--space-sm)));
  }

  :where(.date-picker-clear):-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: var(--date-picker-trigger-px, var(--input-px, var(--space-sm)));
  }

  :where(.date-picker-clear):-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: var(--date-picker-trigger-px, var(--input-px, var(--space-sm)));
  }

  :where(.date-picker-clear):is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: var(--date-picker-trigger-px, var(--input-px, var(--space-sm)));
  }

  :where(.date-picker-clear) > svg {
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.date-picker-clear):hover {
    color: var(--ink);
    background: var(--tint-soft, transparent);
  }

  :where(.date-picker-clear):focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--focus-ring);
  }

  :where(.date-picker-positioner) {
    z-index: var(--z-popover);
    position: absolute;
    inset: 0;
  }

  :where(.date-picker-popover) {
    --surface-radius: var(--radius-md);
    background-color: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--surface-radius);
    box-shadow: var(--shadow-md);
    color: var(--ink);
    padding: var(--space-sm);
    transform-origin: var(--transform-origin);
    animation: date-picker-in var(--duration) var(--ease) both;
  }

  :where(.date-picker-popover)[data-state="closing"] {
    animation: date-picker-out var(--duration) var(--ease) both;
  }

  :where(.date-picker-calendar) {
    --cell-size: 2rem;
  }

  :where(.date-picker-nav) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    padding-block-end: var(--space-sm);
  }

  :where(.date-picker-nav-label) {
    font-weight: var(--weight-medium);
    font-size: var(--text-ui);
  }

  :where(.date-picker-nav-button) {
    display: inline-flex;
    inline-size: var(--cell-size);
    block-size: var(--cell-size);
    border-radius: var(--radius-sm);
    color: var(--ink);
    cursor: default;
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
  }

  :where(.date-picker-nav-button) :where(svg) {
    inline-size: var(--space-md);
    block-size: var(--space-md);
  }

  :where(.date-picker-nav-button):hover {
    background-color: var(--surface-alt);
  }

  :where(.date-picker-nav-button):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: -2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.date-picker-grid) {
    border-collapse: separate;
    border-spacing: 0;
  }

  :where(.date-picker-weekday) {
    font-size: var(--text-caption);
    font-weight: var(--weight-medium);
    color: var(--muted);
    text-align: center;
    inline-size: var(--cell-size);
    padding-block-end: var(--space-xs);
  }

  :where(.date-picker-grid-cell) {
    padding: 1px;
  }

  :where(.date-picker-cell) {
    display: inline-flex;
    inline-size: var(--cell-size);
    block-size: var(--cell-size);
    border-radius: var(--radius-sm);
    font-size: var(--text-ui);
    cursor: default;
    user-select: none;
    color: inherit;
    outline: none;
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
  }

  :where(.date-picker-cell):hover:not([aria-disabled]) {
    background-color: var(--surface-alt);
  }

  :where(.date-picker-cell):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: -2px;
    box-shadow: 0 0 0 4px var(--focus-ring);
  }

  :where(.date-picker-cell)[data-today] {
    font-weight: var(--weight-bold);
    box-shadow: inset 0 -2px 0 var(--accent);
  }

  :where(.date-picker-cell)[data-selected] {
    background-color: var(--accent);
    color: var(--on-accent);
    font-weight: var(--weight-medium);
    box-shadow: none;
  }

  :where(.date-picker-cell)[data-outside] {
    color: var(--muted);
    opacity: .4;
  }

  :where(.date-picker-cell)[aria-disabled] {
    opacity: .25;
    pointer-events: none;
  }

  :where(.date-picker-cell)[data-in-range] {
    background-color: var(--accent-subtle);
    border-radius: 0;
  }

  :where(.date-picker-cell)[data-range-start] {
    background-color: var(--accent);
    color: var(--on-accent);
  }

  :where(.date-picker-cell)[data-range-start]:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: var(--radius-sm);
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: var(--radius-sm);
  }

  :where(.date-picker-cell)[data-range-start]:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: var(--radius-sm);
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: var(--radius-sm);
  }

  :where(.date-picker-cell)[data-range-start]:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: var(--radius-sm);
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: var(--radius-sm);
  }

  :where(.date-picker-cell)[data-range-start]:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-right-radius: var(--radius-sm);
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: var(--radius-sm);
  }

  :where(.date-picker-cell)[data-range-start]:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-right-radius: var(--radius-sm);
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: var(--radius-sm);
  }

  :where(.date-picker-cell)[data-range-start]:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-right-radius: var(--radius-sm);
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: var(--radius-sm);
  }

  :where(.date-picker-cell)[data-range-end] {
    background-color: var(--accent);
    color: var(--on-accent);
  }

  :where(.date-picker-cell)[data-range-end]:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: 0;
    border-top-right-radius: var(--radius-sm);
    border-bottom-right-radius: var(--radius-sm);
    border-bottom-left-radius: 0;
  }

  :where(.date-picker-cell)[data-range-end]:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: 0;
    border-top-right-radius: var(--radius-sm);
    border-bottom-right-radius: var(--radius-sm);
    border-bottom-left-radius: 0;
  }

  :where(.date-picker-cell)[data-range-end]:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    border-top-left-radius: 0;
    border-top-right-radius: var(--radius-sm);
    border-bottom-right-radius: var(--radius-sm);
    border-bottom-left-radius: 0;
  }

  :where(.date-picker-cell)[data-range-end]:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-right-radius: 0;
    border-top-left-radius: var(--radius-sm);
    border-bottom-left-radius: var(--radius-sm);
    border-bottom-right-radius: 0;
  }

  :where(.date-picker-cell)[data-range-end]:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-right-radius: 0;
    border-top-left-radius: var(--radius-sm);
    border-bottom-left-radius: var(--radius-sm);
    border-bottom-right-radius: 0;
  }

  :where(.date-picker-cell)[data-range-end]:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    border-top-right-radius: 0;
    border-top-left-radius: var(--radius-sm);
    border-bottom-left-radius: var(--radius-sm);
    border-bottom-right-radius: 0;
  }

  :where(.date-picker-cell)[data-range-start][data-range-end] {
    border-radius: var(--radius-sm);
  }

  :where(.date-picker-cell)[data-will-be-in-range] {
    background-color: color-mix(in oklab, var(--accent) 6%, transparent);
  }

  :where(.date-picker-time) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    border-block-start: 1px solid var(--line);
    margin-block-start: var(--space-sm);
    padding-block-start: var(--space-sm);
  }

  :where(.date-picker-time-label) {
    font-size: var(--text-caption);
    font-weight: var(--weight-medium);
    color: var(--muted);
  }

  :where(.date-picker-time-inputs) {
    display: flex;
    align-items:  center;
    gap: var(--space-2xs);
  }

  :where(.date-picker-time-input) {
    text-align: center;
    font-size: var(--text-ui);
    font-variant-numeric: tabular-nums;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    color: var(--ink);
    appearance: textfield;
    block-size: 1.75rem;
    inline-size: 2.5rem;
  }

  :where(.date-picker-time-input)::-webkit-inner-spin-button {
    appearance: none;
    margin: 0;
  }

  :where(.date-picker-time-input)::-webkit-outer-spin-button {
    appearance: none;
    margin: 0;
  }

  :where(.date-picker-time-input):focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 1px var(--accent);
  }

  :where(.date-picker-time-separator) {
    font-size: var(--text-ui);
    color: var(--muted);
    font-weight: var(--weight-medium);
  }
}

/* packages/ui/src/styles/blocks/user-picker.css */
@layer components {
  :where(.user-picker) {
    display: flex;
    gap: var(--space-2xs);
    flex-direction: column;
  }

  :where(.user-picker-chips) {
    display: flex;
    gap: var(--space-2xs);
    flex-wrap: wrap;
  }

  :where(.user-picker-chip) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-2xs);
    padding: var(--space-2xs) var(--space-xs);
    background: color-mix(in oklab, var(--accent) 12%, transparent);
    border: 1px solid color-mix(in oklab, var(--accent) 30%, transparent);
    border-radius: var(--radius-full);
    font-size: var(--text-caption);
    color: var(--ink);
    line-height: 1;
  }

  :where(.user-picker-chip-label) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-inline-size: 16rem;
  }

  :where(.user-picker-chip-remove) {
    display: flex;
    cursor: pointer;
    color: var(--muted);
    border-radius: var(--radius-full);
    background: none;
    border: none;
    justify-content: center;
    align-items:  center;
    padding: 0;
    line-height: 1;
  }

  :where(.user-picker-chip-remove):hover {
    color: var(--ink);
  }

  :where(.user-picker-input-wrap) {
    position: relative;
  }

  :where(.user-picker-input) {
    padding: var(--space-xs) var(--space-sm);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--paper);
    color: var(--ink);
    font-size: var(--text-ui);
    outline: none;
    box-sizing: border-box;
    inline-size: 100%;
  }

  :where(.user-picker-input):focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 2px color-mix(in oklab, var(--accent) 20%, transparent);
  }

  :where(.user-picker-dropdown) {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + var(--space-2xs));
    z-index: var(--z-raised);
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    overflow: hidden;
    overflow-y: auto;
    max-block-size: 16rem;
  }

  :where(.user-picker-option) {
    display: flex;
    gap: var(--space-2xs);
    padding: var(--space-xs) var(--space-sm);
    border: none;
    border-block-end: 1px solid color-mix(in oklab, var(--line) 60%, transparent);
    cursor: pointer;
    text-align: start;
    transition: background var(--duration) var(--ease);
    background: none;
    flex-direction: column;
    inline-size: 100%;
  }

  :where(.user-picker-option):last-child {
    border-block-end: none;
  }

  :where(.user-picker-option):hover {
    background: color-mix(in oklab, var(--ink) 4%, transparent);
  }

  :where(.user-picker-option-label) {
    font-size: var(--text-ui);
    color: var(--ink);
    font-weight: var(--weight-medium);
  }

  :where(.user-picker-option-sublabel) {
    font-size: var(--text-caption);
    color: var(--muted);
    font-family: var(--font-mono);
  }

  :where(.user-picker-empty) {
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-ui);
    color: var(--muted);
    text-align: center;
  }
}

/* packages/ui/src/styles/blocks/status-dot.css */
@layer components {
  :where(.status-dot) {
    display: inline-block;
    inline-size: var(--status-dot-size, .5rem);
    block-size: var(--status-dot-size, .5rem);
    border-radius: var(--radius-full);
    background: currentColor;
    flex-shrink: 0;
  }

  .status-dot[data-size="md"] {
    --status-dot-size: var(--space-sm);
  }

  .status-dot[data-pulse] {
    animation: status-dot-pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;
  }

  @keyframes status-dot-pulse {
    0%, 100% {
      opacity: 1;
    }

    50% {
      opacity: .4;
    }
  }
}

/* packages/ui/src/styles/print.css */
@layer components {
  @media print {
    .app-layout {
      display: block !important;
      background: #fff !important;
      min-block-size: 0 !important;
      padding: 0 !important;
    }

    .app-main {
      inline-size: 100% !important;
    }

    .app-shell-content {
      padding: 0 !important;
    }

    .sidebar, .app-topbar, .content-page-sidebar, .content-page-engagement, .content-page-modalities, [data-slot="page-actions-trigger"], [data-slot="page-actions-menu"], .toast, .dialog, .sheet, .dropdown-menu {
      display: none !important;
    }

    .content-page, .content-page-content {
      animation: none !important;
      max-inline-size: 100% !important;
    }

    .comments-section, .ProtectedVideo, .ProtectedImage, .VideoLayer, .children-grid {
      display: none !important;
    }

    body {
      color: #000 !important;
      background: #fff !important;
      font-size: 12pt !important;
      line-height: 1.5 !important;
    }

    h1 {
      font-size: 24pt !important;
    }

    h2 {
      font-size: 18pt !important;
    }

    h3 {
      font-size: 14pt !important;
    }

    a[href^="http"]:after {
      content: " (" attr(href) ")";
      color: #666;
      font-size: 10pt;
    }

    a[href^="/"]:after, a[href^="#"]:after {
      content: none;
    }

    pre, code {
      background: #f5f5f5 !important;
      border: 1px solid #ddd !important;
      font-size: 10pt !important;
    }

    pre {
      white-space: pre-wrap !important;
      word-wrap: break-word !important;
      overflow-x: visible !important;
      padding: 8pt !important;
    }

    pre, blockquote, table, figure, .callout {
      break-inside: avoid;
    }

    h1, h2, h3 {
      break-after: avoid;
    }

    img {
      display: none !important;
    }

    .badge {
      color: #000 !important;
      background: none !important;
      border: 1px solid #999 !important;
    }

    .callout {
      background: #f9f9f9 !important;
      border: 1px solid #999 !important;
    }

    .content-page-meta {
      color: #333 !important;
    }
  }
}

/* packages/ui/src/styles/index.css */


/* packages/ui/src/styles/globals.css */


/* apps/ledger/src/styles/app.css */
@layer components {
  :where(.ledger-table) {
    border-collapse: collapse;
    font-size: var(--text-ui);
    inline-size: 100%;
  }

  :where(.ledger-table) :where(th) {
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--muted);
    text-align: start;
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    border-block-end: 1px solid var(--line);
    white-space: nowrap;
  }

  :where(.ledger-table) :where(.ledger-row) {
    border-block-end: 1px solid color-mix(in oklab, var(--line) 50%, transparent);
    cursor: pointer;
    transition: background var(--duration) var(--ease);
  }

  :where(.ledger-table) :where(.ledger-row):hover {
    background: color-mix(in oklab, var(--ink) 4%, transparent);
  }

  :where(.ledger-table) :where(.ledger-row):focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: -2px;
  }

  :where(.ledger-table) :where(.ledger-row):last-child {
    border-block-end: none;
  }

  :where(.ledger-table) :where(td) {
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    vertical-align: middle;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  :where(.transaction-cell-content:has(.truncate)) {
    overflow: visible;
  }

  :where(.ledger-table) :where(.tooltip-root) {
    max-inline-size: 100%;
  }

  :where(.ledger-table) :where(.truncate) {
    max-inline-size: 100%;
  }

  :where(.ledger-table) :where([data-inactive]) {
    opacity: .5;
  }

  :where(.ledger-table-mono) {
    font-family: var(--font-mono);
    font-size: var(--text-caption);
  }

  :where(.ledger-table-right) {
    text-align: end;
  }

  :where(.ledger-table-center) {
    text-align: center;
  }

  :where(.ledger-table-actions) {
    text-align: end;
    inline-size: 3rem;
  }

  :where(.ledger-table-right) :where([data-slot="badge"]) {
    font-variant-numeric: tabular-nums;
  }

  :where(.transaction-table) {
    table-layout: fixed;
    min-inline-size: 60rem;
  }

  :where(.transaction-table-col-date) {
    width: 5.75rem;
  }

  :where(.transaction-table-col-seq) {
    width: 4rem;
  }

  :where(.transaction-table-col-counterparty) {
    width: 12rem;
  }

  :where(.transaction-table-col-amount) {
    width: 7rem;
  }

  :where(.transaction-table-col-account) {
    width: 8rem;
  }

  :where(.transaction-table-col-type) {
    width: 5.5rem;
  }

  :where(.transaction-table-col-currency) {
    width: 3.5rem;
  }

  :where(.transaction-table-col-ref) {
    width: 5rem;
  }

  :where(.transaction-table-col-attachments) {
    width: 2.5rem;
  }

  :where(.transaction-attachment-icon) {
    color: var(--muted);
    block-size: 1em;
    inline-size: 1em;
  }

  :where(.transaction-cell-content) {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: inherit;
    transition: opacity .12s var(--ease);
    inline-size: 100%;
  }

  :where(.transactions-page) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
    block-size: 100%;
    padding-block-start: 3.236rem;
    padding-block-end: 0;
  }

  :where(.transactions-toolbar) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    flex-shrink: 0;
  }

  :where(.transactions-scroll) {
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    flex: 1;
    min-block-size: 0;
  }

  .transactions-page > .empty {
    flex: none;
    align-self:  center;
    max-inline-size: 28rem;
    margin-block-start: auto;
    margin-block-end: auto;
  }

  :where(.transactions-empty-action) {
    font: inherit;
    color: var(--accent);
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: .15em;
    background: none;
    border: none;
  }

  :where(.transactions-scroll) > :where([data-slot="scroll-area-viewport"]) {
    border-radius: var(--radius-md);
  }

  :where(.transactions-scroll) :where(th) {
    position: sticky;
    background: var(--paper);
    z-index: 1;
    box-shadow: inset 0 -1px 0 var(--line);
    border-block-end: none;
    top: 0;
  }

  :where(.transaction-table[data-transition="out"]) {
    pointer-events: none;
  }

  :where(.transaction-table[data-transition="waiting"]) {
    pointer-events: none;
  }

  :where(.transaction-table[data-transition="pre-in"]) {
    pointer-events: none;
  }

  :where(.transaction-table[data-transition="out"]) :where(.transaction-cell-content) {
    opacity: 0;
  }

  :where(.transaction-table[data-transition="waiting"]) :where(.transaction-cell-content) {
    opacity: 0;
  }

  :where(.transaction-table[data-transition="pre-in"]) :where(.transaction-cell-content) {
    opacity: 0;
  }

  :where(.transaction-table[data-transition="in"]) :where(.transaction-cell-content) {
    opacity: 1;
    transition-duration: .16s;
  }

  @media (prefers-reduced-motion: reduce) {
    :where(.transaction-cell-content) {
      transition: none;
    }
  }

  :where(.transaction-form-dialog) {
    --ledger-form-control-size: var(--control-sm);
    --ledger-form-control-px: var(--space-sm);
    --ledger-form-control-py: var(--space-xs);
    --ledger-form-control-radius: var(--radius-md);
    --field-gap: var(--space-xs);
    --input-size: var(--ledger-form-control-size);
    --input-px: var(--ledger-form-control-px);
    --input-py: var(--ledger-form-control-py);
    --input-radius: var(--ledger-form-control-radius);
    --picker-trigger-size: var(--ledger-form-control-size);
    --picker-trigger-px: var(--ledger-form-control-px);
    --picker-trigger-py: var(--ledger-form-control-py);
    --picker-trigger-radius: var(--ledger-form-control-radius);
    --date-picker-trigger-size: var(--ledger-form-control-size);
    --date-picker-trigger-px: var(--ledger-form-control-px);
    --date-picker-trigger-py: var(--ledger-form-control-py);
    --date-picker-trigger-radius: var(--ledger-form-control-radius);
  }

  :where(.extraction-review-dialog) {
    --ledger-form-control-size: var(--control-sm);
    --ledger-form-control-px: var(--space-sm);
    --ledger-form-control-py: var(--space-xs);
    --ledger-form-control-radius: var(--radius-md);
    --field-gap: var(--space-xs);
    --input-size: var(--ledger-form-control-size);
    --input-px: var(--ledger-form-control-px);
    --input-py: var(--ledger-form-control-py);
    --input-radius: var(--ledger-form-control-radius);
    --picker-trigger-size: var(--ledger-form-control-size);
    --picker-trigger-px: var(--ledger-form-control-px);
    --picker-trigger-py: var(--ledger-form-control-py);
    --picker-trigger-radius: var(--ledger-form-control-radius);
    --date-picker-trigger-size: var(--ledger-form-control-size);
    --date-picker-trigger-px: var(--ledger-form-control-px);
    --date-picker-trigger-py: var(--ledger-form-control-py);
    --date-picker-trigger-radius: var(--ledger-form-control-radius);
  }

  :where(.transaction-form-dialog) {
    --dialog-max-inline-size: 48rem;
  }

  :where(.transaction-form-dialog, .extraction-review-dialog) :where(.segmented-control) {
    --segmented-radius: var(--ledger-form-control-radius);
    --segmented-indicator-radius: calc(var(--ledger-form-control-radius)  - var(--space-3xs));
    --segmented-button-radius: calc(var(--ledger-form-control-radius)  - var(--space-3xs));
    --segmented-block-size-sm: var(--ledger-form-control-size);
    --segmented-font-size-sm: var(--text-ui);
  }

  :where(.transaction-form-dialog, .extraction-review-dialog) :where(.picker) {
    inline-size: 100%;
    min-inline-size: 0;
  }

  :where(.transaction-form-dialog, .extraction-review-dialog) :where(.date-picker) {
    inline-size: 100%;
    min-inline-size: 0;
  }

  :where(.transaction-form-dialog, .extraction-review-dialog) :where(.picker-trigger-control) {
    box-sizing: border-box;
    inline-size: 100%;
  }

  :where(.transaction-form-dialog, .extraction-review-dialog) :where(.date-picker-trigger) {
    box-sizing: border-box;
    inline-size: 100%;
  }

  :where(.transaction-dialog-context) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-sm);
    padding-block-start: var(--space-xs);
  }

  :where(.transaction-dialog-balance) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    font-size: var(--text-ui);
    color: var(--muted);
    font-variant-numeric: tabular-nums;
  }

  :where(.transaction-dialog-balance) :where(strong) {
    color: var(--ink);
    font-weight: var(--weight-semibold);
  }

  :where(.transaction-dialog-bank-trigger) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-2xs);
    font: inherit;
    font-size: var(--text-ui);
    color: var(--muted);
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: color var(--duration) var(--ease);
    background: none;
    border: none;
    padding: 0;
  }

  :where(.transaction-dialog-bank-trigger):hover {
    color: var(--ink);
  }

  :where(.jl) {
    display: flex;
    flex-direction: column;
  }

  :where(.jl-head) {
    display: grid;
    grid-template-columns: 1fr 6.5rem 6.5rem 6rem 2.75rem;
    gap: var(--space-xs);
    align-items:  center;
  }

  :where(.jl-row) {
    display: grid;
    grid-template-columns: 1fr 6.5rem 6.5rem 6rem 2.75rem;
    gap: var(--space-xs);
    align-items:  center;
  }

  :where(.jl-totals) {
    display: grid;
    grid-template-columns: 1fr 6.5rem 6.5rem 6rem 2.75rem;
    gap: var(--space-xs);
    align-items:  center;
  }

  :where(.jl-head) {
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--muted);
    border-block-end: 1px solid var(--line);
    padding-block-end: var(--space-2xs);
  }

  :where(.jl-row) {
    padding-block: var(--space-2xs);
    border-block-end: 1px solid color-mix(in oklab, var(--line) 50%, transparent);
  }

  :where(.jl-row):last-of-type {
    border-block-end: 1px solid var(--line);
  }

  :where(.jl-col-amount) {
    text-align: end;
  }

  :where(.jl-col-action) {
    display: flex;
    justify-content: center;
  }

  :where(.jl-col-account) {
    min-inline-size: 0;
  }

  :where(.jl-col-vat) {
    min-inline-size: 0;
  }

  :where(.jl) :where(.picker-trigger-control) {
    justify-content: flex-start;
    inline-size: 100%;
    min-inline-size: 0;
  }

  :where(.jl) :where([data-slot="picker-value"]) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  :where(.jl-input) {
    text-align: end;
    font-family: var(--font-mono);
    font-variant-numeric: tabular-nums;
  }

  :where(.jl-account-label) {
    display: flex;
    gap: var(--space-2xs);
    font-size: var(--text-ui);
    overflow: hidden;
  }

  :where(.jl-account-code) {
    font-family: var(--font-mono);
    font-weight: var(--weight-medium);
    flex-shrink: 0;
  }

  :where(.jl-account-name) {
    color: var(--muted);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  :where(.jl-amount-value) {
    font-family: var(--font-mono);
    font-size: var(--text-ui);
  }

  :where(.jl-vat-value) {
    font-size: var(--text-caption);
    color: var(--muted);
  }

  :where(.jl-footer) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
    padding-block-start: var(--space-2xs);
  }

  :where(.jl-totals-label) {
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--muted);
  }

  :where(.jl-totals-value) {
    font-family: var(--font-mono);
    font-size: var(--text-ui);
    font-weight: var(--weight-semibold);
  }

  :where(.jl-totals-value[data-zero]) {
    color: var(--muted);
  }

  :where(.jl-footer-row) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
  }

  :where(.jl-balance) {
    font-size: var(--text-caption);
    font-weight: var(--weight-medium);
    padding: var(--space-3xs) var(--space-xs);
    border-radius: var(--radius-sm);
  }

  :where(.jl-balance[data-state="ok"]) {
    background: color-mix(in oklab, var(--positive) 12%, transparent);
    color: var(--positive);
  }

  :where(.jl-balance[data-state="off"]) {
    background: color-mix(in oklab, var(--danger) 12%, transparent);
    color: var(--danger);
  }

  :where(.jl-picker-placeholder) {
    color: var(--muted);
  }

  :where(.jl-account-option) {
    display: flex;
    gap: var(--space-3xs);
    flex-direction: column;
  }

  :where(.jl-account-option-desc) {
    font-size: var(--text-caption);
    color: var(--muted);
  }

  :where(.accounts-description) {
    display: block;
    font-size: var(--text-caption);
    color: var(--muted);
  }

  :where(.jl-toolbar) {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items:  center;
    gap: var(--space-sm);
    margin-block-end: var(--space-sm);
  }

  :where(.jl-vat-toggle) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-sm);
    min-block-size: var(--ledger-form-control-size);
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    cursor: pointer;
  }

  :where(.autofill-group) {
    display: flex;
    justify-content: flex-end;
    align-items:  center;
    gap: var(--space-xs);
    flex-wrap: wrap;
  }

  :where(.autofill-button) {
    gap: var(--space-2xs);
  }

  :where(.jl-vat-annotation) {
    color: var(--muted);
    font-size: var(--text-caption);
  }

  :where(.jl-head-readonly) {
    grid-template-columns: 1fr 6.5rem 6.5rem 8rem;
  }

  :where(.jl-head-readonly) ~ :where(.jl-row) {
    grid-template-columns: 1fr 6.5rem 6.5rem 8rem;
  }

  :where(.jl-switcher) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.jl-help) {
    font-size: var(--text-ui);
    color: var(--muted);
    max-inline-size: 60ch;
    margin: 0;
    line-height: 1.5;
  }

  :where(.jl-bank-header) {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--space-sm);
    align-items:  center;
    margin-block-end: var(--space-sm);
  }

  :where(.jl-bank-account) {
    flex: 1;
    min-inline-size: 0;
  }

  @container dialog (inline-size <= 40rem) {
    :where(.jl-toolbar), :where(.jl-bank-header) {
      grid-template-columns: 1fr;
    }

    :where(.autofill-group) {
      justify-content: flex-start;
    }
  }

  :where(.jl-bank-head) {
    display: grid;
    grid-template-columns: 1fr 6.5rem 6rem 2.75rem;
    gap: var(--space-xs);
    align-items:  center;
  }

  :where(.jl-bank-row) {
    display: grid;
    grid-template-columns: 1fr 6.5rem 6rem 2.75rem;
    gap: var(--space-xs);
    align-items:  center;
  }

  :where(.jl-bank-totals) {
    display: grid;
    grid-template-columns: 1fr 6.5rem 6rem 2.75rem;
    gap: var(--space-xs);
    align-items:  center;
  }

  :where(.jl-bank-head) {
    font-size: var(--text-caption);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--muted);
    border-block-end: 1px solid var(--line);
    padding-block-end: var(--space-2xs);
  }

  :where(.jl-bank-row) {
    padding-block: var(--space-2xs);
    border-block-end: 1px solid color-mix(in oklab, var(--line) 50%, transparent);
  }

  :where(.jl-bank-row):last-of-type {
    border-block-end: 1px solid var(--line);
  }

  :where(.danger-zone) {
    border: 1px solid color-mix(in oklab, var(--danger) 30%, transparent);
    border-radius: var(--radius-md);
    padding: var(--space-md);
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
  }

  :where(.danger-zone-title) {
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--danger);
    margin: 0;
  }

  :where(.danger-zone-desc) {
    font-size: var(--text-ui);
    color: var(--muted);
    margin: 0;
  }

  :where(.danger-zone-label) {
    font-size: var(--text-ui);
  }

  :where(.danger-zone-row) {
    display: flex;
    gap: var(--space-xs);
    align-items:  center;
  }

  :where(.danger-zone-row) :where(input) {
    flex: 1;
  }

  :where(.transaction-detail-grid) {
    display: grid;
    grid-template-columns: 10rem 1fr;
    gap: var(--space-xs) var(--space-md);
    font-size: var(--text-ui);
  }

  :where(.transaction-detail-grid) :where(dt) {
    color: var(--muted);
    font-weight: var(--weight-medium);
  }

  :where(.transaction-detail-grid) :where(dd) {
    margin: 0;
  }

  :where(.settings-dialog) {
    --dialog-max-inline-size: 28rem;
  }

  :where(.settings-form) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.settings-section-header) {
    display: flex;
    justify-content: flex-end;
    margin-block-end: var(--space-sm);
  }

  :where(.settings-general) {
    display: flex;
    gap: var(--space-lg);
    flex-direction: column;
  }

  :where(.settings-section) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.settings-section-title) {
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    margin: 0;
  }

  :where(.ledger-settings-dialog) {
    --dialog-max-inline-size: 54rem;
    --dialog-tabs-sidebar-width: 8rem;
  }

  :where(.ledger-settings-dialog) :where(.dialog-popup) {
    max-block-size: min(36rem, calc(100dvh - var(--space-lg) * 4));
  }

  :where(.ledger-activity-dialog) {
    --dialog-max-inline-size: 56rem;
  }

  :where(.settings-vat-dialog-body) {
    min-block-size: 18rem;
  }

  :where(.settings-sync-row) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
  }

  :where(.settings-loading) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-xs);
    color: var(--muted);
    font-size: var(--text-ui);
    block-size: 100%;
  }

  :where(.settings-fiscal-year) {
    font-family: var(--font-mono);
    font-size: var(--text-ui);
  }

  :where(.settings-error) {
    color: var(--danger);
    font-size: var(--text-ui);
  }

  :where(.stripe-imported) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-2xs);
    color: var(--positive);
    font-size: var(--text-ui);
  }

  :where(.stripe-pending) {
    color: var(--muted);
    font-size: var(--text-ui);
  }

  :where(.page-header-actions) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
  }

  :where(.page-back-link) {
    display: flex;
    align-items:  center;
    gap: var(--space-2xs);
    color: var(--muted);
    text-decoration: none;
    font-size: var(--text-ui);
  }

  :where(.page-back-link):hover {
    color: var(--ink);
  }

  :where(.attachment-dropzone) {
    display: flex;
    padding: var(--space-lg) var(--space-md);
    border: 2px dashed var(--line);
    border-radius: var(--radius-md);
    font: inherit;
    text-align: center;
    justify-content: center;
    align-items:  center;
    gap: var(--space-2xs);
    cursor: pointer;
    color: var(--muted);
    transition: border-color var(--duration) var(--ease), background var(--duration) var(--ease);
    background: none;
    flex-direction: column;
    inline-size: 100%;
  }

  :where(.attachment-dropzone):hover {
    border-color: var(--accent);
    background: color-mix(in oklab, var(--accent) 5%, transparent);
  }

  :where(.attachment-dropzone[data-drag-over]) {
    border-color: var(--accent);
    background: color-mix(in oklab, var(--accent) 5%, transparent);
  }

  :where(.attachment-dropzone:disabled) {
    cursor: wait;
    opacity: .7;
  }

  :where(.attachment-dropzone-hint) {
    font-size: var(--text-caption);
    color: var(--muted);
  }

  :where(.attachment-error) {
    font-size: var(--text-ui);
    color: var(--danger);
  }

  :where(.attachment-list) {
    font-size: var(--text-ui);
  }

  :where(.attachment-item) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    padding-block: var(--space-2xs);
    border-block-end: 1px solid color-mix(in oklab, var(--line) 50%, transparent);
  }

  :where(.attachment-item:last-child) {
    border-block-end: none;
  }

  :where(.attachment-icon) {
    color: var(--muted);
    flex-shrink: 0;
  }

  :where(.attachment-name) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
    min-inline-size: 0;
  }

  :where(.attachment-size) {
    font-size: var(--text-caption);
    color: var(--muted);
    flex-shrink: 0;
  }

  :where(.attachment-badge) {
    --badge-fg: var(--accent);
    --badge-bg: var(--accent-subtle);
    flex-shrink: 0;
  }

  :where(.attachment-secondary-actions) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.scans-page) {
    display: flex;
    gap: var(--space-lg);
    flex-direction: column;
  }

  :where(.scans-header) {
    display: flex;
    justify-content: space-between;
    align-items:  flex-start;
    gap: var(--space-md);
  }

  :where(.scans-upload-card) {
    background: linear-gradient(135deg, color-mix(in oklab, var(--accent) 8%, transparent), transparent 60%), var(--surface);
  }

  :where(.scans-grid) {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
    gap: var(--space-md);
    list-style: none;
    margin: 0;
    padding: 0;
  }

  :where(.scan-card) {
    block-size: 100%;
  }

  :where(.scan-card-header) {
    padding-block-end: var(--space-xs);
  }

  :where(.scan-card-heading) {
    display: flex;
    justify-content: space-between;
    align-items:  flex-start;
    gap: var(--space-sm);
  }

  :where(.scan-card-file) {
    display: flex;
    align-items:  flex-start;
    gap: var(--space-sm);
    min-inline-size: 0;
  }

  :where(.scan-card-file-copy) {
    min-inline-size: 0;
  }

  :where(.scan-card-title) {
    font-size: var(--text-lg);
    line-height: var(--leading-snug);
    word-break: break-word;
  }

  :where(.scan-card-badges) {
    display: flex;
    justify-content: flex-end;
    gap: var(--space-2xs);
    flex-wrap: wrap;
  }

  :where(.scan-card-content) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.scan-card-extraction) {
    display: flex;
    gap: var(--space-xs);
    padding: var(--space-sm);
    border-radius: var(--radius-md);
    background: color-mix(in oklab, var(--accent) 6%, var(--surface));
    flex-direction: column;
  }

  :where(.scan-card-summary) {
    display: flex;
    gap: var(--space-3xs);
    flex-direction: column;
  }

  :where(.scan-card-summary) :where(strong) {
    font-size: var(--text-ui);
  }

  :where(.scan-card-summary) :where(span) {
    font-size: var(--text-ui);
    color: var(--muted);
    margin: 0;
  }

  :where(.scan-card-empty) {
    font-size: var(--text-ui);
    color: var(--muted);
    margin: 0;
  }

  :where(.scan-card-meta) {
    display: flex;
    gap: var(--space-xs);
    font-size: var(--text-caption);
    color: var(--muted);
    flex-wrap: wrap;
  }

  :where(.scan-card-actions) {
    display: flex;
    gap: var(--space-xs);
    flex-wrap: wrap;
  }

  :where(.scans-empty) {
    min-block-size: 10rem;
  }

  :where(.scan-picker-empty) {
    min-block-size: 10rem;
  }

  :where(.scan-picker-loading) {
    min-block-size: 10rem;
  }

  :where(.scan-picker-loading) {
    display: flex;
    justify-content: center;
    align-items:  center;
  }

  :where(.scan-picker-dialog) {
    --dialog-max-inline-size: 44rem;
  }

  :where(.scan-picker-scroll) {
    max-block-size: 26rem;
  }

  :where(.scan-picker-list) {
    display: flex;
    gap: var(--space-sm);
    list-style: none;
    flex-direction: column;
    margin: 0;
    padding: 0;
  }

  :where(.scan-picker-row) {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--space-sm);
    padding: var(--space-sm);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--surface);
    color: inherit;
    font: inherit;
    text-align: start;
    cursor: pointer;
    align-items:  flex-start;
    inline-size: 100%;
  }

  :where(.scan-picker-card) {
    display: flex;
    gap: var(--space-xs);
    flex-direction: column;
    min-inline-size: 0;
  }

  :where(.scan-picker-meta) {
    display: flex;
    gap: var(--space-3xs);
    font-size: var(--text-caption);
    color: var(--muted);
    flex-direction: column;
  }

  :where(.scan-picker-title) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    color: var(--ink);
    font-size: var(--text-ui);
  }

  :where(.scan-picker-summary) {
    display: flex;
    gap: var(--space-3xs);
    font-size: var(--text-ui);
    color: var(--muted);
    flex-direction: column;
  }

  @media (max-width: 48rem) {
    :where(.scans-header) {
      flex-direction: column;
      align-items:  flex-start;
    }

    :where(.attachment-secondary-actions) {
      inline-size: 100%;
    }

    :where(.transaction-detail-grid) {
      grid-template-columns: 8rem 1fr;
    }
  }

  :where(.reports-grid) {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr));
    gap: var(--space-md);
    margin-block-end: var(--space-lg);
  }

  :where(.report-card-link) {
    text-decoration: none;
    color: inherit;
  }

  :where(.report-card-icon) {
    color: var(--accent);
    flex-shrink: 0;
    block-size: 1.25rem;
    inline-size: 1.25rem;
  }

  :where(.report-card-desc) {
    font-size: var(--text-ui);
    color: var(--muted);
    margin: 0;
    margin-block-start: var(--space-2xs);
  }

  :where(.report-card-meta) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    font-size: var(--text-ui);
  }

  :where(.report-card-deadline) {
    color: var(--muted);
  }

  :where(.report-controls) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    margin-block-end: var(--space-sm);
  }

  :where(.report-period-info) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
    font-size: var(--text-ui);
    color: var(--muted);
    margin-block-end: var(--space-md);
  }

  :where(.report-deadline) {
    color: var(--muted);
  }

  :where(.report-loading) {
    display: flex;
    padding: var(--space-lg);
    justify-content: center;
  }

  :where(.page-header-back) {
    display: flex;
    gap: var(--space-2xs);
    flex-direction: column;
  }

  :where(.back-link) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-2xs);
    font-size: var(--text-ui);
    color: var(--muted);
    text-decoration: none;
  }

  :where(.back-link:hover) {
    color: var(--ink);
  }

  :where(.back-link svg) {
    block-size: .875rem;
    inline-size: .875rem;
  }

  :where(.report-actions) {
    display: flex;
    justify-content: flex-end;
    gap: var(--space-sm);
    padding-block: var(--space-md);
    border-block-start: 1px solid var(--line);
    margin-block-start: var(--space-md);
  }

  :where(.section-title) {
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    margin-block: var(--space-md) var(--space-sm);
  }

  :where(.saved-reports) {
    margin-block-start: var(--space-lg);
  }

  :where(.saved-report-groups) {
    display: grid;
    gap: var(--space-md);
  }

  :where(.saved-report-group) {
    overflow: hidden;
  }

  :where(.saved-report-group-header) {
    padding-block-end: 0;
  }

  :where(.saved-report-actions) {
    display: flex;
    justify-content: flex-end;
    gap: var(--space-2xs);
    flex-wrap: wrap;
  }

  :where(.omavero-table) {
    max-inline-size: 48rem;
  }

  :where(.omavero-code) {
    white-space: nowrap;
    inline-size: 4rem;
  }

  :where(.omavero-section-header td) {
    font-weight: var(--weight-semibold);
    font-size: var(--text-ui);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--muted);
    border-block-end: 2px solid var(--line);
    padding-block-start: var(--space-md);
  }

  :where(.omavero-row-308) {
    font-weight: var(--weight-semibold);
    background: var(--surface-alt);
  }

  :where(.report-summary-row td) {
    font-weight: var(--weight-semibold);
    border-block-start: 2px solid var(--line);
  }

  :where(.oss-country-section) {
    margin-block-end: var(--space-lg);
  }

  :where(.oss-country-header) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    margin-block-end: var(--space-sm);
  }

  :where(.oss-grand-total) {
    max-inline-size: 30rem;
    margin-inline-start: auto;
  }

  :where(.tp-document) {
    max-inline-size: 56rem;
    margin-inline-start: auto;
    margin-inline-end: auto;
  }

  :where(.tp-header) {
    border-block-end: 2px solid var(--line);
    margin-block-end: var(--space-xl);
    padding-block-end: var(--space-md);
  }

  :where(.tp-company-name) {
    font-size: var(--text-lg);
    font-weight: var(--weight-bold);
    margin-block-end: var(--space-sm);
  }

  :where(.tp-header p) {
    font-size: var(--text-ui);
    color: var(--muted);
    line-height: 1.6;
  }

  :where(.tp-section) {
    margin-block-end: var(--space-xl);
  }

  :where(.tp-section-title) {
    font-size: var(--text-base);
    font-weight: var(--weight-bold);
    border-block-end: 1px solid var(--line);
    margin-block-end: var(--space-md);
    padding-block-end: var(--space-xs);
  }

  :where(.tp-side-title) {
    font-size: var(--text-ui);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--muted);
    margin-block: var(--space-md) var(--space-sm);
  }

  :where(.tp-table) {
    border-collapse: collapse;
    font-size: var(--text-ui);
    inline-size: 100%;
  }

  :where(.tp-table th) {
    text-align: start;
    font-weight: var(--weight-medium);
    padding-block: var(--space-xs);
    border-block-end: 1px solid var(--line);
    color: var(--muted);
    font-size: var(--text-caption);
  }

  :where(.tp-table td) {
    padding-block: var(--space-2xs);
  }

  :where(.tp-amount-col) {
    text-align: end;
    min-inline-size: 8rem;
  }

  :where(.tp-amount) {
    text-align: end;
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
  }

  :where(.tp-prior-col) {
    opacity: .7;
  }

  :where(.tp-section-header td) {
    font-weight: var(--weight-semibold);
    font-size: var(--text-ui);
    padding-block-start: var(--space-sm);
  }

  :where(.tp-group-header td) {
    font-weight: var(--weight-medium);
    color: var(--muted);
    font-size: var(--text-ui);
    padding-block-start: var(--space-xs);
  }

  :where(.tp-account-row .tp-account-name) {
    padding-inline-start: var(--space-md);
  }

  :where(.tp-subtotal td) {
    font-weight: var(--weight-medium);
    padding-block-start: var(--space-2xs);
  }

  :where(.tp-section-total td) {
    font-weight: var(--weight-semibold);
    border-block-start: 1px solid var(--line);
    padding-block: var(--space-xs);
  }

  :where(.tp-grand-total td) {
    font-weight: var(--weight-bold);
    font-size: var(--text-base);
    border-block-start: 2px solid var(--line);
    padding-block: var(--space-sm);
  }

  :where(.tp-notes-list) {
    font-size: var(--text-ui);
    padding-inline-start: var(--space-lg);
    line-height: 1.6;
  }

  :where(.tp-notes-list li) {
    margin-block-end: var(--space-xs);
  }

  :where(.tp-text-block) {
    font-size: var(--text-ui);
    white-space: pre-wrap;
    line-height: 1.6;
  }

  :where(.tp-approval) {
    display: grid;
    gap: var(--space-sm);
    max-inline-size: 42rem;
  }

  :where(.tp-placeholder) {
    font-size: var(--text-ui);
    color: var(--muted);
    font-style: italic;
  }

  :where(.tp-signatures) {
    max-inline-size: 28rem;
  }

  :where(.tp-signature-location) {
    font-size: var(--text-ui);
    margin-block-end: var(--space-lg);
  }

  :where(.tp-signature-line) {
    margin-block-end: var(--space-lg);
  }

  :where(.tp-approval-signature) {
    margin-block-start: var(--space-sm);
  }

  :where(.tp-approval-signature-label) {
    font-size: var(--text-ui);
    margin-block-end: var(--space-xs);
  }

  :where(.tp-signature-rule) {
    border-block-end: 1px solid var(--line);
    inline-size: 16rem;
    margin-block-end: var(--space-2xs);
  }

  :where(.tp-signature-name) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
  }

  :where(.tp-signature-title) {
    font-size: var(--text-caption);
    color: var(--muted);
  }

  :where(.tp-custom-note-row) {
    display: flex;
    gap: var(--space-sm);
    align-items:  center;
    margin-block-end: var(--space-sm);
  }

  :where(.tp-signer-row) {
    display: flex;
    gap: var(--space-sm);
    align-items:  center;
    margin-block-end: var(--space-sm);
  }

  :where(.tp-custom-note-row input) {
    flex: 1;
  }

  :where(.tp-signer-row input) {
    flex: 1;
  }

  :where(.ledger-customer-dialog-row) {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
  }

  :where(.ledger-customer-row-actions) {
    display: flex;
    gap: var(--space-2xs);
    justify-content: flex-end;
  }

  :where(.ledger-customer-rate-actions) {
    display: flex;
    gap: var(--space-2xs);
    justify-content: flex-end;
  }

  :where(.ledger-customer-rate-edit) {
    display: flex;
    gap: var(--space-sm);
    align-items:  center;
  }

  :where(.ledger-customer-rate-edit) :where(.input) {
    min-inline-size: 0;
  }

  :where(.is-archived) {
    opacity: .55;
  }

  :where(.time-page) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
    block-size: 100%;
    padding-block-start: var(--space-xl);
    padding-block-end: 0;
  }

  :where(.time-summary) {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
    gap: var(--space-sm);
    flex-shrink: 0;
  }

  :where(.time-summary-card) {
    --card-padding: var(--space-sm);
    display: flex;
    gap: var(--space-3xs);
    flex-direction: column;
  }

  :where(.time-summary-card-wide) {
    grid-column: span 2;
  }

  :where(.time-summary-label) {
    font-size: var(--text-caption);
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .05em;
  }

  :where(.time-summary-value) {
    font-size: var(--text-xl);
    font-variant-numeric: tabular-nums;
  }

  :where(.time-summary-list) {
    list-style: none;
    display: flex;
    gap: var(--space-3xs);
    flex-direction: column;
    margin: 0;
    padding: 0;
  }

  :where(.time-summary-list-item) {
    display: flex;
    justify-content: space-between;
    gap: var(--space-sm);
    font-size: var(--text-ui);
  }

  :where(.time-summary-list-value) {
    font-variant-numeric: tabular-nums;
    color: var(--muted);
  }

  :where(.time-table-note) {
    max-inline-size: 18rem;
  }

  :where(.time-status-draft) {
    --badge-bg: color-mix(in oklab, var(--accent) 10%, transparent);
    --badge-fg: var(--accent);
  }

  :where(.time-status-invoiced) {
    --badge-bg: color-mix(in oklab, var(--ink) 8%, transparent);
    --badge-fg: var(--muted);
  }

  :where(.invoices-page) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
    block-size: 100%;
    padding-block-start: var(--space-xl);
  }

  :where(.invoice-status-draft) {
    --badge-bg: color-mix(in oklab, var(--ink) 8%, transparent);
    --badge-fg: var(--muted);
  }

  :where(.invoice-status-issued) {
    --badge-bg: color-mix(in oklab, var(--accent) 12%, transparent);
    --badge-fg: var(--accent);
  }

  :where(.invoice-status-paid) {
    --badge-bg: color-mix(in oklab, var(--positive) 12%, transparent);
    --badge-fg: var(--positive);
  }

  :where(.invoice-status-credited) {
    --badge-bg: color-mix(in oklab, var(--ink) 8%, transparent);
    --badge-fg: var(--muted);
  }

  :where(.invoice-credited-title) {
    text-decoration: line-through;
  }

  :where(.invoice-edit-page) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    padding-block-start: var(--space-xl);
    padding-block-end: var(--space-md);
  }

  :where(.invoice-detail-page) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    padding-block-start: var(--space-xl);
    padding-block-end: var(--space-md);
  }

  :where(.invoice-edit-header) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    flex-wrap: wrap;
  }

  :where(.invoice-detail-header) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    flex-wrap: wrap;
  }

  :where(.invoice-detail-title) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    flex: 1;
  }

  :where(.invoice-edit-actions) {
    display: flex;
    gap: var(--space-2xs);
    margin-inline-start: auto;
  }

  :where(.invoice-detail-actions) {
    display: flex;
    gap: var(--space-2xs);
    margin-inline-start: auto;
  }

  :where(.invoice-edit-grid) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.invoice-totals-panel) {
    align-self:  flex-end;
    min-inline-size: 20rem;
  }

  :where(.invoice-totals) {
    display: flex;
    gap: var(--space-3xs);
    flex-direction: column;
    margin: 0;
  }

  :where(.invoice-totals-row) {
    display: flex;
    justify-content: space-between;
    gap: var(--space-md);
  }

  :where(.invoice-totals-term) {
    color: var(--muted);
  }

  :where(.invoice-totals-def) {
    font-variant-numeric: tabular-nums;
    margin: 0;
  }

  :where(.invoice-totals-grand) {
    font-weight: var(--weight-semibold);
    border-block-start: 1px solid var(--line);
    padding-block-start: var(--space-2xs);
  }

  :where(.invoice-manual-lines) {
    display: flex;
    gap: var(--space-sm);
    flex-direction: column;
  }

  :where(.invoice-manual-line) {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr 1fr auto;
    gap: var(--space-2xs);
    align-items:  center;
  }

  :where(.invoice-view-meta) {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
  }

  :where(.invoice-view-meta-list) {
    display: flex;
    gap: var(--space-2xs);
    flex-direction: column;
    margin: 0;
  }

  :where(.invoice-view-meta-term) {
    font-size: var(--text-caption);
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .05em;
  }

  :where(.invoice-view-meta-def) {
    margin: 0;
  }

  :where(.invoice-notes) {
    border-block-start: 1px solid var(--line);
    padding-block-start: var(--space-sm);
  }

  :where(.dashboard-section) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.dashboard-section-header) {
    display: flex;
    justify-content: space-between;
    align-items:  flex-end;
    gap: var(--space-md);
    flex-wrap: wrap;
  }

  :where(.dashboard-section-copy) {
    display: flex;
    gap: var(--space-3xs);
    flex-direction: column;
  }

  :where(.dashboard-section-title) {
    font-size: var(--text-lg);
    font-weight: var(--weight-semibold);
    margin: 0;
  }

  :where(.dashboard-section-meta) {
    color: var(--muted);
    font-size: var(--text-ui);
    margin: 0;
  }

  :where(.dashboard-period-trigger) {
    justify-content: space-between;
    min-inline-size: 15rem;
  }

  :where(.dashboard-balance-trigger) {
    font-weight: var(--weight-semibold);
    justify-content: space-between;
    inline-size: 100%;
  }

  :where(.clearing-banner) {
    display: flex;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    background: color-mix(in oklch, var(--warning) 10%, transparent);
    border: 1px solid color-mix(in oklch, var(--warning) 30%, transparent);
    border-radius: var(--radius-md);
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
    color: var(--warning);
    text-decoration: none;
  }

  :where(.clearing-banner:hover) {
    background: color-mix(in oklch, var(--warning) 15%, transparent);
  }

  :where(.deadline-task-list) {
    display: flex;
    gap: var(--space-xs);
    list-style: none;
    flex-direction: column;
    margin: 0;
    padding: 0;
  }

  :where(.deadline-task-item) {
    display: flex;
    justify-content: space-between;
    align-items:  center;
    gap: var(--space-sm);
    padding: var(--space-xs) 0;
    border-block-end: 1px solid var(--line);
  }

  :where(.deadline-task-item:last-child) {
    border-block-end: none;
  }

  :where(.deadline-task-info) {
    display: flex;
    gap: var(--space-3xs);
    flex-direction: column;
    min-inline-size: 0;
  }

  :where(.deadline-task-title) {
    font-size: var(--text-ui);
    font-weight: var(--weight-medium);
  }

  :where(.deadline-task-due) {
    font-size: var(--text-caption);
    color: var(--muted);
  }

  @media (max-width: 40rem) {
    :where(.dashboard-period-trigger) {
      inline-size: 100%;
    }
  }

  :where(.reconciliation-card) {
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    overflow: hidden;
  }

  :where(.reconciliation-summary) {
    display: flex;
    align-items:  center;
    gap: var(--space-md);
    padding: var(--space-sm) var(--space-md);
    text-align: start;
    font: inherit;
    cursor: pointer;
    outline-offset: -2px;
    background: none;
    border: none;
    inline-size: 100%;
  }

  :where(.reconciliation-summary:hover) {
    background: color-mix(in oklab, var(--ink) 4%, transparent);
  }

  :where(.reconciliation-date) {
    font-variant-numeric: tabular-nums;
    color: var(--muted);
    font-size: var(--text-ui);
    min-inline-size: 6rem;
  }

  :where(.reconciliation-counterparty) {
    font-weight: var(--weight-medium);
    flex: 1;
  }

  :where(.reconciliation-amount) {
    font-variant-numeric: tabular-nums;
    font-weight: var(--weight-medium);
    text-align: end;
    min-inline-size: 6rem;
  }

  :where(.reconciliation-collapse) {
    display: grid;
    grid-template-rows: 0fr;
    overflow: hidden;
    transition: grid-template-rows var(--duration) var(--ease);
  }

  :where(.reconciliation-collapse)[data-state="open"] {
    grid-template-rows: 1fr;
  }

  :where(.reconciliation-collapse-inner) {
    overflow: hidden;
    min-height: 0;
  }

  :where(.reconciliation-form) {
    padding: var(--space-sm) var(--space-md) var(--space-md);
    border-block-start: 1px solid var(--line);
    background: var(--surface);
  }

  :where(.reconciliation-form-row) {
    display: flex;
    gap: var(--space-md);
    flex-wrap: wrap;
    align-items:  end;
  }

  :where(.reconciliation-field) {
    display: flex;
    gap: var(--space-2xs);
    flex-direction: column;
  }

  :where(.reconciliation-field-account) {
    flex: 1;
    min-inline-size: 14rem;
  }

  :where(.reconciliation-field-toggle) {
    align-items:  center;
    gap: var(--space-sm);
    flex-direction: row;
    padding-block-end: var(--space-2xs);
  }

  :where(.reconciliation-label) {
    font-size: var(--text-caption);
    font-weight: var(--weight-medium);
    color: var(--muted);
  }

  :where(.reconciliation-field) :where(.picker-trigger) {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    padding-block: var(--space-xs);
    padding-inline: var(--space-sm);
    font-size: var(--text-ui);
    transition: border-color var(--duration) var(--ease);
    min-block-size: 0;
    inline-size: 100%;
  }

  :where(.reconciliation-field) :where(.picker-trigger:hover) {
    border-color: var(--line-strong, var(--line));
  }

  :where(.reconciliation-form-actions) {
    display: flex;
    justify-content: flex-end;
    margin-block-start: var(--space-sm);
  }

  :where(.attachment-actions) {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: stretch;
    gap: var(--space-sm);
  }

  :where(.scanner-trigger) {
    gap: var(--space-2xs);
    align-self: stretch;
  }

  :where(.extraction-review-dialog) {
    --dialog-max-inline-size: 56rem;
  }

  :where(.er-layout) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  @container dialog (inline-size > 40rem) {
    :where(.er-layout) {
      flex-direction: row;
      align-items:  flex-start;
    }

    :where(.er-thumbnails) {
      flex-direction: column;
      inline-size: 12rem;
      flex-shrink: 0;
      max-block-size: 100%;
      overflow-y: auto;
    }

    :where(.er-fields) {
      flex: 1;
      min-inline-size: 0;
    }
  }

  :where(.er-thumbnails) {
    display: flex;
    gap: var(--space-xs);
    overflow-x: auto;
  }

  :where(.er-thumb) {
    object-fit: cover;
    border-radius: var(--radius-md);
    border: 1px solid var(--line);
    flex-shrink: 0;
    block-size: 8rem;
    inline-size: 8rem;
  }

  :where(.er-thumb-pdf) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-2xs);
    background: var(--surface);
    color: var(--muted);
    font-size: var(--text-caption);
    text-align: center;
    padding: var(--space-xs);
    overflow: hidden;
    flex-direction: column;
  }

  :where(.er-fields) {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.er-header-fields) {
    display: grid;
    grid-template-columns: 10rem 1fr;
    gap: var(--space-sm);
  }

  @container dialog (inline-size < 30rem) {
    :where(.er-header-fields) {
      grid-template-columns: 1fr;
    }
  }

  @container dialog (inline-size <= 36rem) {
    :where(.attachment-actions) {
      grid-template-columns: 1fr;
    }

    :where(.attachment-secondary-actions) {
      inline-size: 100%;
    }
  }

  :where(.er-legs-heading) {
    font-size: var(--text-ui);
    font-weight: var(--weight-semibold);
    color: var(--muted);
    margin: 0;
  }

  :where(.scanner-dialog) {
    --dialog-max-inline-size: 100vw;
    --dialog-padding-block: 0;
    --dialog-padding-inline: 0;
    --scanner-bg: oklch(0 0 0);
    --scanner-fg: oklch(1 0 0);
    --scanner-overlay-dark: oklch(0 0 0 / .7);
    --scanner-overlay-gradient: oklch(0 0 0 / .6);
    --scanner-shadow: oklch(0 0 0 / .3);
    --scanner-mask-fill: oklch(0 0 0 / .35);
    --scanner-inset-bg: oklch(0 0 0 / .5);
    --scanner-fg-dim: oklch(1 0 0 / .7);
    --scanner-fg-bright: oklch(1 0 0 / .85);
    --scanner-fg-faint: oklch(1 0 0 / .6);
    --scanner-debug-bg: oklch(0 0 0 / .55);
    background: var(--scanner-bg);
    color: var(--scanner-fg);
    overflow: hidden;
    display: flex;
    border-radius: 0;
    flex-direction: column;
    block-size: 100dvh;
    max-block-size: 100dvh;
  }

  :where(.scanner-dialog[data-phase="captured"]) {
    --dialog-max-inline-size: 48rem;
    --dialog-padding-block: var(--space-md);
    --dialog-padding-inline: var(--space-md);
    border-radius: var(--radius-lg);
    background: var(--surface);
    color: var(--ink);
    block-size: auto;
    max-block-size: min(85dvh, 52rem);
  }

  :where(.scanner-loading) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-md);
    color: var(--muted);
    flex-direction: column;
    flex: 1;
  }

  :where(.scanner-camera) {
    position: relative;
    overflow: hidden;
    display: flex;
    background: var(--scanner-bg);
    flex: 1;
    justify-content: center;
    align-items:  center;
  }

  :where(.scanner-video) {
    object-fit: cover;
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.scanner-overlay) {
    position: absolute;
    pointer-events: none;
    block-size: 100%;
    inline-size: 100%;
    inset: 0;
  }

  :where(.scanner-mask) {
    fill: var(--scanner-mask-fill);
    transition: opacity .2s;
  }

  :where(.scanner-bracket) {
    fill: none;
    stroke: var(--accent);
    stroke-width: 2.5px;
    stroke-linecap: round;
    stroke-linejoin: round;
    transition: stroke .3s;
  }

  :where(.scanner-bracket[data-confident]) {
    stroke: var(--positive);
  }

  :where(.scanner-bracket-review) {
    stroke: var(--accent);
    stroke-width: 2px;
  }

  :where(.scanner-selection-overlay) {
    position: absolute;
    pointer-events: none;
    inset: 0;
  }

  :where(.scanner-selection-outline) {
    fill: none;
    stroke: var(--accent);
    stroke-width: 1px;
    stroke-opacity: .4;
  }

  :where(.scanner-hint) {
    position: absolute;
    top: calc(var(--space-md)  + env(safe-area-inset-top));
    background: var(--scanner-overlay-dark);
    color: var(--scanner-fg);
    padding: var(--space-xs) var(--space-md);
    border-radius: var(--radius-md);
    font-size: var(--text-ui);
    pointer-events: none;
    animation: scanner-hint-fade-in .3s ease;
    left: 50%;
    transform: translateX(-50%);
  }

  @keyframes scanner-hint-fade-in {
    from {
      opacity: 0;
      transform: translateX(-50%)translateY(-.5rem);
    }

    to {
      opacity: 1;
      transform: translateX(-50%)translateY(0);
    }
  }

  :where(.scanner-toolbar) {
    position: absolute;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items:  center;
    gap: var(--space-md);
    padding: var(--space-lg) var(--space-lg) calc(var(--space-lg)  + env(safe-area-inset-bottom));
    background: linear-gradient(transparent, var(--scanner-overlay-gradient));
    bottom: 0;
    left: 0;
    right: 0;
  }

  :where(.scanner-toolbar-btn) {
    color: var(--scanner-fg);
    justify-self: start;
  }

  :where(.scanner-debug-toggle) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    font-size: var(--text-ui);
    color: var(--scanner-fg-dim);
    cursor: pointer;
    justify-self: end;
  }

  :where(.scanner-shutter) {
    --shutter-size: 4.25rem;
    --shutter-ring: 3px;
    appearance: none;
    border: var(--shutter-ring) solid var(--scanner-fg);
    width: var(--shutter-size);
    height: var(--shutter-size);
    display: inline-flex;
    cursor: pointer;
    color: inherit;
    background: none;
    border-radius: 50%;
    justify-content: center;
    align-items:  center;
    padding: 0;
    transition: transform .12s, border-color .12s;
  }

  :where(.scanner-shutter:hover) {
    border-color: var(--scanner-fg-bright, var(--scanner-fg));
  }

  :where(.scanner-shutter:focus-visible) {
    outline: 2px solid var(--focus-ring);
    outline-offset: 3px;
  }

  :where(.scanner-shutter:active) {
    transform: scale(.94);
  }

  :where(.scanner-shutter:disabled) {
    opacity: .4;
    cursor: not-allowed;
  }

  :where(.scanner-shutter-inner) {
    display: block;
    background: var(--scanner-fg);
    border-radius: 50%;
    block-size: calc(100% - 10px);
    inline-size: calc(100% - 10px);
    transition: inline-size .12s, block-size .12s;
  }

  :where(.scanner-shutter:active .scanner-shutter-inner) {
    block-size: calc(100% - 16px);
    inline-size: calc(100% - 16px);
  }

  :where(.scanner-shutter-stack) {
    display: flex;
    align-items:  center;
    gap: var(--space-xs);
    flex-direction: column;
    justify-self: center;
  }

  :where(.scanner-capture-path) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-3xs);
    padding: var(--space-3xs) var(--space-2xs);
    border-radius: var(--radius-sm);
    font-size: var(--text-caption);
    color: var(--scanner-fg);
    backdrop-filter: blur(4px);
    white-space: nowrap;
    background: #00000073;
  }

  :where(.scanner-capture-path-dot) {
    background: currentColor;
    border-radius: 50%;
    block-size: .5em;
    inline-size: .5em;
  }

  :where(.scanner-capture-path[data-tone="good"]) {
    color: oklch(.85 .18 150);
  }

  :where(.scanner-capture-path[data-tone="warn"]) {
    color: oklch(.85 .18 80);
  }

  :where(.scanner-capture-path[data-tone="manual"]) {
    color: var(--scanner-fg-dim, var(--scanner-fg));
  }

  :where(.scanner-debug-overlay) {
    position: absolute;
    top: calc(var(--space-md)  + env(safe-area-inset-top)  + 2.5rem);
    left: var(--space-sm);
    display: flex;
    color: var(--scanner-fg-bright);
    background: var(--scanner-debug-bg);
    padding: var(--space-2xs) var(--space-xs);
    border-radius: var(--radius-sm);
    pointer-events: none;
    z-index: 2;
    flex-direction: column;
    gap: 1px;
    font-family: ui-monospace, monospace;
    font-size: .6875rem;
    line-height: 1.3;
  }

  :where(.scanner-debug-indicator) {
    display: inline-flex;
    align-items:  center;
    gap: var(--space-3xs);
  }

  :where(.scanner-debug) {
    position: absolute;
    bottom: calc(3.5rem + env(safe-area-inset-bottom));
    display: flex;
    gap: var(--space-xs);
    z-index: 1;
    pointer-events: auto;
    flex-direction: column;
    left: 0;
    right: 0;
  }

  :where(.scanner-debug-pinned) {
    display: flex;
    align-items:  center;
    gap: var(--space-3xs);
    padding-inline: var(--space-sm);
    cursor: pointer;
    flex-direction: column;
  }

  :where(.scanner-debug-pinned-canvas) {
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    block-size: 14rem;
    inline-size: auto;
  }

  :where(.scanner-debug-pinned-label) {
    font-size: .6875rem;
    font-weight: var(--weight-medium);
    color: var(--scanner-fg-bright);
    text-transform: uppercase;
    letter-spacing: .04em;
  }

  :where(.scanner-debug-strip) {
    display: flex;
    justify-content: center;
    gap: var(--space-2xs);
    padding: var(--space-xs) var(--space-sm);
    flex-wrap: wrap;
  }

  @media (min-width: 36rem) {
    :where(.scanner-debug-strip) {
      overflow-x: auto;
      scrollbar-width: none;
      flex-wrap: nowrap;
      justify-content: flex-start;
    }
  }

  :where(.scanner-debug-stage) {
    display: flex;
    align-items:  center;
    gap: var(--space-3xs);
    cursor: pointer;
    opacity: .7;
    flex-direction: column;
    flex: none;
    transition: opacity .12s;
  }

  :where(.scanner-debug-stage:hover) {
    opacity: 1;
  }

  :where(.scanner-debug-stage[data-pinned]) {
    opacity: 1;
  }

  :where(.scanner-debug-stage[data-pinned]) :where(.scanner-debug-label) {
    color: var(--accent);
  }

  :where(.scanner-debug-canvas) {
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-md);
    block-size: 4rem;
    inline-size: auto;
  }

  :where(.scanner-debug-stage[data-pinned]) :where(.scanner-debug-canvas) {
    outline: 2px solid var(--accent);
    outline-offset: 1px;
  }

  :where(.scanner-debug-label) {
    color: var(--scanner-fg-faint);
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: .04em;
    font-size: .5625rem;
  }

  :where(.scanner-dialog[data-phase="captured"]) :where(.scanner-preview) {
    position: relative;
    display: flex;
    overflow: hidden;
    background: var(--surface-alt);
    border-radius: var(--radius-sm);
    flex: 1;
    justify-content: center;
    align-items:  center;
    min-block-size: 12rem;
  }

  :where(.scanner-preview-image) {
    display: flex;
    justify-content: center;
    align-items:  center;
    max-block-size: 100%;
    max-inline-size: 100%;
  }

  :where(.scanner-preview-source) {
    block-size: 100%;
    inline-size: 100%;
  }

  :where(.scanner-preview-canvas) {
    object-fit: contain;
    max-block-size: 100%;
    max-inline-size: 100%;
  }

  :where(.scanner-preview-inset) {
    position: absolute;
    right: var(--space-sm);
    top: var(--space-sm);
    padding: var(--space-3xs);
    border-radius: var(--radius-sm);
    background: var(--scanner-inset-bg);
    backdrop-filter: blur(8px);
    pointer-events: none;
    max-block-size: 25%;
    max-inline-size: min(10rem, 30vw);
  }

  :where(.scanner-handles) {
    position: absolute;
    inset: 0;
  }

  :where(.scanner-handle) {
    position: absolute;
    border-radius: var(--radius-full);
    cursor: grab;
    touch-action: none;
    z-index: 1;
    background: none;
    border: none;
    block-size: 2rem;
    inline-size: 2rem;
    transform: translate(-50%, -50%);
  }

  :where(.scanner-handle:active) {
    cursor: grabbing;
  }

  :where(.scanner-footer) {
    gap: var(--space-md);
    flex-direction: column;
  }

  :where(.scanner-actions) {
    display: flex;
    justify-content: flex-end;
    gap: var(--space-sm);
  }

  :where(.scanner-error) {
    display: flex;
    justify-content: center;
    align-items:  center;
    gap: var(--space-md);
    padding: var(--space-xl);
    color: var(--muted);
    text-align: center;
    flex-direction: column;
    flex: 1;
  }

  @media (max-width: 48rem) {
    :where(.scanner-toolbar) {
      padding-inline: var(--space-md);
    }

    :where(.scanner-preview-inset) {
      max-block-size: min(6rem, 20vh);
      max-inline-size: min(7rem, 28vw);
    }

    :where(.scanner-debug-canvas) {
      block-size: 3rem;
    }

    :where(.scanner-debug-pinned-canvas) {
      block-size: 10rem;
    }

    :where(.scanner-actions) {
      flex-wrap: wrap;
    }
  }

  @media (pointer: coarse) {
    :where(.scanner-handle) {
      block-size: 2.75rem;
      inline-size: 2.75rem;
    }
  }
}
