/*! tailwindcss v4.1.10 | MIT License | https://tailwindcss.com */
@layer properties;
@layer base, component, blocks, compositions, utilities, demo;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji",
      "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-mono: 0.25;
    --color-teal-300: oklch(85.5% 0.138 181.071);
    --color-teal-400: oklch(77.7% 0.152 181.912);
    --color-teal-500: oklch(70.4% 0.14 182.503);
    --color-gray-200: oklch(92.8% 0.006 264.531);
    --color-gray-300: oklch(87.2% 0.01 258.338);
    --color-gray-700: oklch(37.3% 0.034 259.733);
    --color-neutral-100: var(--color-stone-100);
    --color-neutral-200: var(--color-stone-200);
    --color-neutral-300: var(--color-stone-300);
    --color-neutral-400: var(--color-stone-400);
    --color-neutral-500: var(--color-stone-500);
    --color-neutral-600: var(--color-stone-600);
    --color-neutral-700: var(--color-stone-700);
    --color-neutral-800: var(--color-stone-800);
    --color-neutral-950: var(--color-stone-950);
    --color-stone-50: oklch(98.5% 0.001 106.423);
    --color-stone-100: oklch(97% 0.001 106.424);
    --color-stone-200: oklch(92.3% 0.003 48.717);
    --color-stone-300: oklch(86.9% 0.005 56.366);
    --color-stone-400: oklch(70.9% 0.01 56.259);
    --color-stone-500: oklch(55.3% 0.013 58.071);
    --color-stone-600: oklch(44.4% 0.011 73.639);
    --color-stone-700: oklch(37.4% 0.01 67.558);
    --color-stone-800: oklch(26.8% 0.007 34.298);
    --color-stone-900: oklch(21.6% 0.006 56.043);
    --color-stone-950: oklch(14.7% 0.004 49.25);
    --color-white: #fff;
    --spacing: 0.25rem;
    --text-xs: var(--text--2);
    --text-xs--line-height: 1.8;
    --text-sm: var(--text--1);
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-lg: var(--text-1);
    --text-lg--line-height: 1.6;
    --text-xl: var(--text-2);
    --text-xl--line-height: 1.3;
    --text-2xl: var(--text-3);
    --text-2xl--line-height: 1.2;
    --text-3xl: var(--text-4);
    --text-3xl--line-height: 1.1;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --radius-md: 0.375rem;
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
    --color-fg-end: light-dark(var(--color-stone-950),
      var(--color-stone-50));
    --color-primary: light-dark(var(--color-teal-500),
      var(--color-teal-400));
    --color-focus: light-dark(var(--color-teal-400),
      var(--color-teal-300));
    --color-mute: light-dark(var(--color-stone-400),
      var(--color-stone-500));
    --color-subtle: light-dark(var(--color-stone-400),
      var(--color-stone-700));
    --color-sheet: light-dark(var(--color-stone-100),
      var(--color-stone-950));
    --color-sheet-fg: light-dark(var(--color-stone-900),
      var(--color-stone-300));
    --color-sheet-bg: light-dark(var(--color-stone-100),
      var(--color-stone-800));
    --mute: var(--color-mute);
    --spacing-root: var(--spacing-xs-ss);
    --spacing-xs: clamp(0.75rem, 0.6848rem + 0.3261vw, 0.9375rem);
    --spacing-sm: clamp(1rem, 0.913rem + 0.4348vw, 1.25rem);
    --spacing-md: clamp(1.5rem, 1.3696rem + 0.6522vw, 1.875rem);
    --spacing-lg: clamp(2rem, 1.8261rem + 0.8696vw, 2.5rem);
    --spacing-xl: clamp(3rem, 2.7391rem + 1.3043vw, 3.75rem);
    --spacing-2xl: clamp(4rem, 3.6522rem + 1.7391vw, 5rem);
    --spacing-xs-ss: clamp(0.75rem, 0.5761rem + 0.8696vw, 1.25rem);
    --spacing-lg-3xl: clamp(2rem, 0.087rem + 9.5652vw, 7.5rem);
    --font-recursive: RecVar, system-ui, sans-serif;
    --font-weight: 380;
    --font-casual: 1;
    --font-cursive: 0.5;
    --font-slant: 1;
    --text--2: clamp(0.64rem, 0.6179rem + 0.1104vw, 0.7035rem);
    --text--1: clamp(0.8rem, 0.7521rem + 0.2395vw, 0.9377rem);
    --text-0: clamp(1rem, 0.913rem + 0.4348vw, 1.25rem);
    --text-1: clamp(1.25rem, 1.1052rem + 0.7239vw, 1.6663rem);
    --text-2: clamp(1.5625rem, 1.3334rem + 1.1454vw, 2.2211rem);
    --text-3: clamp(1.9531rem, 1.6026rem + 1.7524vw, 2.9607rem);
    --text-4: clamp(2.4414rem, 1.9178rem + 2.6178vw, 3.9467rem);
    --text-xs--letter-spacing: 0.40px;
    --text-xs--font-weight: 400;
    --text-sm--letter-spacing: 0.20px;
    --text-sm--font-weight: 400;
    --text-md: var(--text-0);
    --text-md--line-height: 1.6;
    --text-md--font-weight: 400;
    --text-lg--font-weight: 500;
    --text-xl--font-weight: 600;
    --text-2xl--font-weight: 900;
    --text-3xl--letter-spacing: -0.50px;
    --text-3xl--font-weight: 900;
    --theme-bg-placeholder: light-dark(var(--color-neutral-100), var(--color-neutral-800));
    --theme-bg-highlight-placeholder: light-dark(var(--color-neutral-100), var(--color-neutral-800));
    --theme-bg-accent-placeholder: light-dark(var(--color-neutral-200), var(--color-neutral-700));
    --theme-bg-mute-placeholder: light-dark(var(--color-neutral-300), var(--color-neutral-600));
    --theme-fg-placeholder: light-dark(var(--color-neutral-400), var(--color-neutral-600));
    --theme-fg-highlight-placeholder: light-dark(var(--color-neutral-800), var(--color-neutral-100));
    --theme-fg-accent-placeholder: light-dark(var(--color-neutral-700), var(--color-neutral-200));
    --theme-fg-mute-placeholder: light-dark(var(--color-neutral-600), var(--color-neutral-300));
    --theme-border-placeholder: light-dark(var(--color-neutral-200), var(--color-neutral-800));
    --theme-border-highlight-placeholder: light-dark(var(--color-neutral-400), var(--color-neutral-500));
    --theme-border-accent-placeholder: light-dark(var(--color-neutral-500), var(--color-neutral-400));
    --theme-border-mute-placeholder: light-dark(var(--color-neutral-600), var(--color-neutral-300));
    --theme-shadow-placeholder: light-dark(var(--color-neutral-800), var(--color-neutral-950));
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .static {
    position: static;
  }
  .col-span-2 {
    grid-column: span 2 / span 2;
  }
  .col-span-full {
    grid-column: 1 / -1;
  }
  .mx-auto {
    margin-inline: auto;
  }
  .my-2xl {
    margin-block: var(--spacing-2xl);
  }
  .mr-2 {
    margin-right: calc(var(--spacing) * 2);
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .mb-sm {
    margin-bottom: var(--spacing-sm);
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline-block {
    display: inline-block;
  }
  .max-w-prose {
    max-width: 65ch;
  }
  .interactive {
    cursor: pointer;
    &:focus, &:hover {
      --color-theme-bg: var(--theme-bg-highlight);
      --color-theme-fg: var(--theme-fg-highlight);
      --color-theme-border: var(--theme-border-highlight);
    }
  }
  .list-disc {
    list-style-type: disc;
  }
  .grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid-cols-\[1fr_auto\] {
    grid-template-columns: 1fr auto;
  }
  .grid-cols-\[auto_1fr\] {
    grid-template-columns: auto 1fr;
  }
  .grid-cols-subgrid {
    grid-template-columns: subgrid;
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .items-center {
    align-items: center;
  }
  .gap-root {
    gap: var(--spacing-root);
  }
  .gap-xs {
    gap: var(--spacing-xs);
  }
  .space-y-\[0\.33lh\] {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(0.33lh * var(--tw-space-y-reverse));
      margin-block-end: calc(0.33lh * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-lg {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(var(--spacing-lg) * var(--tw-space-y-reverse));
      margin-block-end: calc(var(--spacing-lg) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-md {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(var(--spacing-md) * var(--tw-space-y-reverse));
      margin-block-end: calc(var(--spacing-md) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-sm {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(var(--spacing-sm) * var(--tw-space-y-reverse));
      margin-block-end: calc(var(--spacing-sm) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-xl {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(var(--spacing-xl) * var(--tw-space-y-reverse));
      margin-block-end: calc(var(--spacing-xl) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .gap-x-sm {
    column-gap: var(--spacing-sm);
  }
  .gap-y-\[0\.5lh\] {
    row-gap: 0.5lh;
  }
  .rounded-full {
    border-radius: calc(infinity * 1px);
  }
  .border-l {
    border-left-style: var(--tw-border-style);
    border-left-width: 1px;
  }
  .border-l-2 {
    border-left-style: var(--tw-border-style);
    border-left-width: 2px;
  }
  .bg-gray-200 {
    background-color: var(--color-gray-200);
  }
  .bg-neutral-100 {
    background-color: var(--color-neutral-100);
  }
  .p-root {
    padding: var(--spacing-root);
  }
  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }
  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }
  .py-1 {
    padding-block: calc(var(--spacing) * 1);
  }
  .pt-1 {
    padding-top: calc(var(--spacing) * 1);
  }
  .pl-4 {
    padding-left: calc(var(--spacing) * 4);
  }
  .pl-root {
    padding-left: var(--spacing-root);
  }
  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
    letter-spacing: var(--tw-tracking, var(--text-sm--letter-spacing));
    font-weight: var(--tw-font-weight, var(--text-sm--font-weight));
  }
  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
    letter-spacing: var(--tw-tracking, var(--text-xs--letter-spacing));
    font-weight: var(--tw-font-weight, var(--text-xs--font-weight));
  }
  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
    font-weight: var(--tw-font-weight, var(--text-lg--font-weight));
  }
  .text-md {
    font-size: var(--text-md);
    line-height: var(--tw-leading, var(--text-md--line-height));
    font-weight: var(--tw-font-weight, var(--text-md--font-weight));
  }
  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }
  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }
  .text-gray-700 {
    color: var(--color-gray-700);
  }
  .italic {
    font-style: italic;
  }
  .stack {
    --_gap: var(--gap, var(--spacing-md));
    & > * + * {
      margin-block-start: var(--_gap);
    }
  }
  .font-bold {
    --font-weight: 700;
  }
  .text-lg {
    --font-weight: 500;
  }
  .text-md {
    --font-weight: 400;
  }
  .text-sm {
    --font-weight: 400;
  }
  .text-xs {
    --font-weight: 400;
  }
  .\*\:space-y-md {
    :is(& > *) {
      :where(& > :not(:last-child)) {
        --tw-space-y-reverse: 0;
        margin-block-start: calc(var(--spacing-md) * var(--tw-space-y-reverse));
        margin-block-end: calc(var(--spacing-md) * calc(1 - var(--tw-space-y-reverse)));
      }
    }
  }
  .dark\:bg-gray-700 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-gray-700);
    }
  }
  .dark\:text-gray-300 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-gray-300);
    }
  }
  .any-link\:underline {
    & a:any-link, &:any-link {
      text-decoration-line: underline;
    }
  }
  .any-link\:decoration-mute {
    & a:any-link, &:any-link {
      text-decoration-color: var(--color-mute);
    }
  }
  .any-link\:underline-offset-4 {
    & a:any-link, &:any-link {
      text-underline-offset: 4px;
    }
  }
  .\[\&_address\]\:text-sm {
    & address {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
      letter-spacing: var(--tw-tracking, var(--text-sm--letter-spacing));
      font-weight: var(--tw-font-weight, var(--text-sm--font-weight));
    }
  }
  .\[\&_address\]\:italic {
    & address {
      font-style: italic;
    }
  }
  .\[\&_address\]\:text-sm {
    & address {
      --font-weight: 400;
    }
  }
  .\[\&_h1\]\:text-3xl {
    & h1 {
      font-size: var(--text-3xl);
      line-height: var(--tw-leading, var(--text-3xl--line-height));
      letter-spacing: var(--tw-tracking, var(--text-3xl--letter-spacing));
      font-weight: var(--tw-font-weight, var(--text-3xl--font-weight));
    }
  }
  .\[\&_h1\]\:text-3xl {
    & h1 {
      --font-weight: 900;
    }
  }
  .\[\&_h2\]\:mt-lg {
    & h2 {
      margin-top: var(--spacing-lg);
    }
  }
  .\[\&_h2\]\:mb-md {
    & h2 {
      margin-bottom: var(--spacing-md);
    }
  }
  .\[\&_h2\]\:text-lg {
    & h2 {
      font-size: var(--text-lg);
      line-height: var(--tw-leading, var(--text-lg--line-height));
      font-weight: var(--tw-font-weight, var(--text-lg--font-weight));
    }
  }
  .\[\&_h2\]\:text-lg {
    & h2 {
      --font-weight: 500;
    }
  }
  .\[\&_header\,\&_h3\,\&_p\]\:contents {
    & header,& h3,& p {
      display: contents;
    }
  }
  .\[\&_li\]\:mb-\[0\.25lh\] {
    & li {
      margin-bottom: 0.25lh;
    }
  }
  .\[\&_p_strong\]\:font-bold {
    & p strong {
      --tw-font-weight: var(--font-weight-bold);
      font-weight: var(--font-weight-bold);
    }
  }
  .\[\&_p_strong\]\:font-bold {
    & p strong {
      --font-weight: 700;
    }
  }
  .\[\&_strong\]\:font-bold {
    & strong {
      --tw-font-weight: var(--font-weight-bold);
      font-weight: var(--font-weight-bold);
    }
  }
  .\[\&_strong\]\:italic {
    & strong {
      font-style: italic;
    }
  }
  .\[\&_strong\]\:font-bold {
    & strong {
      --font-weight: 700;
    }
  }
  .\[\&_ul\]\:mb-xs {
    & ul {
      margin-bottom: var(--spacing-xs);
    }
  }
  .\[\&_ul\]\:list-disc {
    & ul {
      list-style-type: disc;
    }
  }
  .\[\&_ul\]\:space-y-\[0\.25lh\] {
    & ul {
      :where(& > :not(:last-child)) {
        --tw-space-y-reverse: 0;
        margin-block-start: calc(0.25lh * var(--tw-space-y-reverse));
        margin-block-end: calc(0.25lh * calc(1 - var(--tw-space-y-reverse)));
      }
    }
  }
  .\[\&_ul\]\:pl-4 {
    & ul {
      padding-left: calc(var(--spacing) * 4);
    }
  }
  .\[\&_ul\]\:pl-md {
    & ul {
      padding-left: var(--spacing-md);
    }
  }
  .\[\&_ul\]\:text-sm {
    & ul {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
      letter-spacing: var(--tw-tracking, var(--text-sm--letter-spacing));
      font-weight: var(--tw-font-weight, var(--text-sm--font-weight));
    }
  }
  .\[\&_ul\]\:text-sm {
    & ul {
      --font-weight: 400;
    }
  }
  .\[\&_ul\,\&_ol\]\:list-disc {
    & ul,& ol {
      list-style-type: disc;
    }
  }
  .\[\&_ul\,\&_ol\]\:pl-root {
    & ul,& ol {
      padding-left: var(--spacing-root);
    }
  }
  .\[\&\>li\]\:contents {
    &>li {
      display: contents;
    }
  }
}
.size-container {
  container-type: size;
}
:root {
  font-family: var(--font-recursive), system-ui, sans-serif;
  font-size: 13pt;
  line-height: 1.5;
}
* {
  font-variation-settings: 'wght' var(--font-weight), 'slnt' var(--font-slant), 'CASL' var(--font-casual), 'CRSV' var(--font-cursive), 'MONO' var(--font-mono);
}
@property --font-weight {
  syntax: "<number>";
  initial-value: 400;
  inherits: true;
}
@property --font-casual {
  syntax: "<number>";
  initial-value: 1;
  inherits: true;
}
@utilty set-* {
  background-color: --value(--color-theme-bg-*);
  color: --value(--color-theme-fg-*);
  border-color: --value(--color-theme-border-*);
  outline-color: --value(--color-theme-border-*);
}
:root {
  color-scheme: light dark;
}
html, body {
  min-height: 100%;
}
tbody th {
  text-align: left;
}
th, td {
  padding: var(--spacing);
}
:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: var(--spacing);
}
@layer component {
  .link {
    &:visited, &:link {
      color: var(--color-teal-500);
      text-underline-offset: 0.25rem;
      text-decoration: underline;
      text-decoration-color: transparent;
      transition: color 250ms ease-out, --font-weight 250ms ease-out, --font-casual 150ms ease-out;
    }
    &:focus, &:hover {
      --font-casual: 0;
      --font-weight: 800;
      text-decoration: underline;
      text-decoration-color: var(--color-primary);
      color: inherit;
    }
  }
}
@layer article.base, article.adjust;
@layer article.base {
  .article {
    --vise-width: 70rch;
    --article-base-space: 0;
    &, .content {
      margin-inline: auto;
    }
    & > *, .content > * {
      max-inline-size: var(--vise-width);
      margin-inline: auto;
    }
    & > * + *, .content > * + * {
      margin-block-start: var(--space-before, var(--spacing-md));
    }
    a:any-link {
      color: var(--color-theme-fg-accent);
      text-decoration: underline;
      text-decoration-color: var(--color-theme-border-accent);
      text-underline-offset: 0.2em;
      text-decoration-thickness: 0.1em;
      &:focus, &:hover {
        color: var(--color-theme-fg-highlight);
        text-decoration-color: var(--color-theme-border-hilight);
        @media (prefers-color-scheme: dark) {
          --font-weight: 800;
          text-shadow: 0 0 0.2em var(--color-theme-fg-highlight);
        }
      }
    }
  }
}
@layer article.adjust {
  .article {
    --font-casual: 0;
    --font-cursive: 1;
    header {
      --vise-width: 100rch;
      margin-block: var(--spacing-lg-3xl);
    }
    h1, h2, h3, h4, h5 {
      --font-casual: 1;
      --font-cursive: 1;
      --space-before: var(--spacing-xl);
    }
    h1 {
      font-size: var(--text-3xl);
      line-height: var(--tw-leading, var(--text-3xl--line-height));
      letter-spacing: var(--tw-tracking, var(--text-3xl--letter-spacing));
      font-weight: var(--tw-font-weight, var(--text-3xl--font-weight));
      --font-weight: 900;
      --font-weight: 900;
      --font-slant: -7.5;
      line-height: 1.1;
    }
    h2 {
      font-size: var(--text-xl);
      line-height: var(--tw-leading, var(--text-xl--line-height));
      font-weight: var(--tw-font-weight, var(--text-xl--font-weight));
      --font-weight: 600;
      --font-weight: 900;
      --space-before: var(--spacing-2xl);
    }
    h3 {
      font-size: var(--text-lg);
      line-height: var(--tw-leading, var(--text-lg--line-height));
      font-weight: var(--tw-font-weight, var(--text-lg--font-weight));
      --font-weight: 500;
      --font-weight: 800;
      --space-before: var(--spacing-2xl);
    }
    h4, h5 {
      --font-weight: 700;
    }
    h5, h6 {
      color: var(--color-mute);
    }
    h6 {
      --space-before: var(--spacing-md);
    }
    em {
      --font-weight: 400;
      --font-casual: 1;
      --font-cursive: 1;
      --font-slant: -15;
    }
    strong {
      --font-weight: 700;
      color: var(--color-fg-end);
    }
    ul:not([class]) {
      list-style: disc;
      padding-left: var(--spacing-lg);
      & li::marker {
        color: var(--color-subtle);
      }
      li:has(>p:first-child>a:only-child):has(p:nth-child(2n)) {
        margin-bottom: calc(var(--spacing) * 4);
        p:nth-child(2) {
          margin-top: calc(var(--spacing) * 2);
        }
        p:nth-child(n+2) {
          font-size: var(--text-sm);
          line-height: var(--tw-leading, var(--text-sm--line-height));
          letter-spacing: var(--tw-tracking, var(--text-sm--letter-spacing));
          font-weight: var(--tw-font-weight, var(--text-sm--font-weight));
          --font-weight: 400;
        }
      }
    }
    pre:has(+h2) {
      --mb: calc(var(--spacing) * 16);
    }
    pre, code {
      --font-mono: 1;
      --font-casual: 0;
      --font-cursive: 1;
      --font-weight: 500;
    }
    details[open] summary {
      margin-bottom: var(--mb);
    }
    summary {
      font-size: var(--text-sm);
      cursor: pointer;
      color: var(--mute);
    }
    example-code:has(+output) {
      margin-block: var(--spacing-xl);
    }
    example-code, example-code+output {
      font-size: var(--text-sm);
      line-height: 1.6;
      letter-spacing: 0.02em;
    }
    example-code + output:not {
      font-size: var(--text-xs);
    }
    example-code:has(+output) {
      &, & + output {
        margin-block-start: var(--spacing-lg);
        margin-block-end: var(--spacing-2xl);
      }
    }
    .footnotes {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
      letter-spacing: var(--tw-tracking, var(--text-sm--letter-spacing));
      font-weight: var(--tw-font-weight, var(--text-sm--font-weight));
      --font-weight: 400;
      ol {
        border-top: 1px dashed var(--color-subtle);
        padding: var(--spacing-sm);
        list-style: numbered;
      }
    }
  }
  small {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
    letter-spacing: var(--tw-tracking, var(--text-xs--letter-spacing));
    font-weight: var(--tw-font-weight, var(--text-xs--font-weight));
    --font-weight: 400;
    color: var(--color-mute);
  }
}
.box {
  display: block;
  background: var(--color-sheet);
  padding: var(--spacing-sm);
  box-sizing: content-box;
  border-radius: var(--radius-md);
}
@layer block {
  .input {
    background-color: var(--color-theme-bg);
    color: var(--color-theme-fg);
    border-color: var(--color-theme-border);
    outline-color: var(--color-theme-border);
    display: block;
    width: 100%;
    border-width: 2px;
  }
}
.card {
  border-radius: 0.5rem;
  background: var(--color-sheet);
  padding: var(--spacing-sm);
  border: 1px solid var(--color-subtle);
}
.links {
  :any-link {
    color: var(--color-theme-fg-accent);
    text-decoration: underline;
    text-decoration-color: var(--color-theme-border-accent);
    text-underline-offset: 0.2em;
    text-decoration-thickness: 0.1em;
    &:focus, &:hover {
      color: var(--color-theme-fg-highlight);
      text-decoration-color: var(--color-theme-border-hilight);
      @media (prefers-color-scheme: dark) {
        --font-weight: 800;
        text-shadow: 0 0 0.2em var(--color-theme-fg-highlight);
      }
    }
  }
}
@layer blocks {
  .placeholder {
    --color-theme-bg: var(--theme-bg-placeholder);
    --color-theme-bg-highlight: var(--theme-bg-highlight-placeholder);
    --color-theme-bg-accent: var(--theme-bg-accent-placeholder);
    --color-theme-bg-mute: var(--theme-bg-mute-placeholder);
    --color-theme-fg: var(--theme-fg-placeholder);
    --color-theme-fg-highlight: var(--theme-fg-highlight-placeholder);
    --color-theme-fg-accent: var(--theme-fg-accent-placeholder);
    --color-theme-fg-mute: var(--theme-fg-mute-placeholder);
    --color-theme-border: var(--theme-border-placeholder);
    --color-theme-border-highlight: var(--theme-border-highlight-placeholder);
    --color-theme-border-accent: var(--theme-border-accent-placeholder);
    --color-theme-border-mute: var(--theme-border-mute-placeholder);
    > * {
      --color-theme-shadow: var(--theme-shadow-placeholder);
    }
    color-scheme: light dark;
    background: var(--color-theme-bg);
    padding: var(--spacing-sm);
    border: 4px dashed var(--color-theme-border);
    border-radius: var(--radius-md);
    color: var(--color-theme-fg);
    header {
      margin-bottom: var(--spacing-xs);
    }
  }
}
.callout {
  background: var(--color-sheet-bg);
  padding: var(--spacing-sm);
  color: var(--color-sheet-fg);
}
.callout:where(details) {
  padding: 0;
  summary {
    padding: var(--spacing-sm);
  }
  & > .article {
    margin-block-start: var(--spacing-sm);
    padding-inline: var(--spacing-sm);
    padding-block-end: var(--spacing-md);
    margin-inline: var(--spacing-sm);
  }
}
.callout {
  background: var(--color-theme-bg);
  padding: var(--spacing-xs);
  border: 2px solid var(--color-theme-border);
  border-radius: var(--radius-md);
  color: var(--color-theme-fg);
  header {
    margin-bottom: var(--spacing-xs);
  }
}
.breadcrumbs {
  --font-mono: 1;
  :any-link {
    text-decoration: unset;
    &:where([aria-current]) {
      color: var(--color-mute);
    }
    &:focus-visible, &:hover {
      color: var(--color-focus);
    }
  }
  display: flex;
  align-items: center;
  gap: 0.5ch;
  & > li {
    display: contents;
    &:not(:last-child)::after {
      display: inline-block;
      content: '/';
      margin: 0 0.25ch;
    }
    &:last-child > a {
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
  }
}
.copy-button {
  cursor: pointer;
  color: hsl(from var(--color-white) h s l / 50%);
  padding: 0.5em;
  background: hsl(from black h s l / 70%);
  backdrop-filter: blur(2px);
  border-radius: var(--radius-md);
  &:hover {
    color: var(--color-white);
  }
  &:active {
    color: var(--color-primary);
  }
}
.example-code, example-code {
  position: relative;
  display: block;
  box-shadow: var(--shadow-xl);
  z-index: 2;
  &:has(+output) {
    margin-bottom: 0;
  }
  & > pre, & + output {
    font-family: var(--font-mono);
    --font-mono: 1;
    border-radius: var(--radius-md);
  }
  & > pre {
    overflow: auto;
    padding: var(--spacing-sm);
    margin-inline: calc(var(--spacing-sm) * -1);
  }
  & + output {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column-reverse;
    max-height: 8lh;
    overflow: auto;
    padding: var(--spacing-sm);
    margin-block-start: 0;
    border-block-start: 0;
    border-start-start-radius: 0;
    border-start-end-radius: 0;
    background: var(--color-sheet);
  }
  .copy-button {
    position: absolute;
    right: 0;
    top: var(--spacing-xs);
  }
}
pre.autumn-hl {
  background-color: #232136;
  color: #e0def4;
}
.ahl-info {
  color: #9ccfd8;
}
.ahl-label {
  color: #9ccfd8;
}
.ahl-markup.ahl-heading.ahl-marker {
  color: #6e6a86;
}
.ahl-markup.ahl-bold {
  font-weight: bold;
}
.ahl-diff {
  color: #393552;
}
.ahl-namespace {
  color: #e0def4;
}
.ahl-diagnostic {
  color: #908caa;
}
.ahl-markup.ahl-heading {
  font-weight: bold;
  color: #c4a7e7;
}
.ahl-markup.ahl-heading.ahl-1 {
  font-weight: bold;
  color: #c4a7e7;
}
.ahl-constant.ahl-builtin {
  color: #eb6f92;
}
.ahl-markup.ahl-heading.ahl-6 {
  font-weight: bold;
  color: #9ccfd8;
}
.ahl-attribute {
  color: #c4a7e7;
}
.ahl-type {
  color: #9ccfd8;
}
.ahl-diagnostic.ahl-warning {
  color: #f6c177;
}
.ahl-hint {
  color: #c4a7e7;
}
.ahl-constant {
  color: #9ccfd8;
}
.ahl-constant.ahl-builtin.ahl-boolean {
  color: #ea9a97;
}
.ahl-markup.ahl-link {
  color: #c4a7e7;
}
.ahl-warning {
  color: #f6c177;
}
.ahl-variable {
  color: #e0def4;
}
.ahl-constructor {
  color: #9ccfd8;
}
.ahl-markup.ahl-heading.ahl-2 {
  font-weight: bold;
  color: #9ccfd8;
}
.ahl-diagnostic.ahl-error {
  color: #eb6f92;
}
.ahl-diff.ahl-minus {
  color: #eb6f92;
}
.ahl-constant.ahl-character {
  color: #f6c177;
}
.ahl-markup.ahl-raw {
  color: #908caa;
}
.ahl-tag {
  color: #9ccfd8;
}
.ahl-comment {
  font-style: italic;
  color: #6e6a86;
}
.ahl-markup.ahl-link.ahl-text {
  color: #e0def4;
}
.ahl-punctuation {
  color: #908caa;
}
.ahl-markup.ahl-italic {
  font-style: italic;
}
.ahl-special {
  color: #ea9a97;
}
.ahl-diff.ahl-plus {
  color: #9ccfd8;
}
.ahl-operator {
  color: #908caa;
}
.ahl-diagnostic.ahl-info {
  color: #9ccfd8;
}
.ahl-constant.ahl-character.ahl-escape {
  color: #3e8fb0;
}
.ahl-markup.ahl-link.ahl-url {
  text-decoration: underline;
  color: #c4a7e7;
  color: #c4a7e7;
}
.ahl-variable.ahl-builtin {
  color: #eb6f92;
}
.ahl-variable.ahl-parameter {
  color: #c4a7e7;
}
.ahl-string {
  color: #f6c177;
}
.ahl-diff.ahl-delta {
  color: #56526e;
}
.ahl-keyword {
  color: #3e8fb0;
}
.ahl-markup.ahl-heading.ahl-3 {
  font-weight: bold;
  color: #ea9a97;
}
.ahl-markup.ahl-heading.ahl-5 {
  font-weight: bold;
  color: #3e8fb0;
}
.ahl-markup.ahl-heading.ahl-4 {
  font-weight: bold;
  color: #f6c177;
}
.ahl-markup.ahl-quote {
  color: #908caa;
}
.ahl-function.ahl-builtin {
  color: #eb6f92;
}
.ahl-markup.ahl-link.ahl-label {
  color: #908caa;
}
.ahl-markup.ahl-list {
  color: #6e6a86;
}
.ahl-keyword.ahl-operator {
  color: #908caa;
}
.ahl-diagnostic.ahl-hint {
  color: #c4a7e7;
}
.ahl-variable.ahl-other.ahl-member {
  color: #9ccfd8;
}
.ahl-function {
  color: #ea9a97;
}
.ahl-constant.ahl-numeric {
  color: #f6c177;
}
.ahl-debug {
  color: #ea9a97;
}
.ahl-error {
  color: #eb6f92;
}
.bar {
  --_gap: var(--bar-gap, var(--spacing-sm));
  display: flex;
  flex-direction: row;
  gap: var(--_gap);
  width: max-content;
  > * {
    min-width: max-content;
  }
}
.bookend {
  display: flex;
  gap: var(--gap);
  justify-content: center;
  align-items: center;
  width: 100%;
  & > :first-child, & > :last-child {
    flex-grow: 0;
  }
  & > * {
    flex-grow: 1;
  }
}
.bridge {
  width: 100%;
  display: flex;
  gap: var(--gap);
  & > :nth-child(1), & > :nth-child(3) {
    flex-shrink: 0;
  }
  & > :nth-child(2) {
    flex-grow: 1;
    overflow: auto;
  }
}
*:has(> .cover) {
  container-type: inline-size;
}
.flank-end, .flank {
  --_gap: var(--gap, var(--root-gap, 1rem));
  display: flex;
  gap: var(--_gap);
  align-items: center;
  justify-content: stretch;
  & > :first-child {
    flex-grow: 0;
    flex-shrink: 0;
  }
  & > :last-child {
    flex-grow: 999;
    flex-shrink: 1;
    min-inline-size: 0;
  }
}
.flank-end {
  & > :first-child {
    flex-grow: 999;
    flex-shrink: 1;
    min-inline-size: 0;
  }
  & > :last-child {
    flex-grow: 0;
    flex-shrink: 0;
  }
}
@layer compositions {
  .flex-stretch {
    display: flex;
    justify-content: stretch;
    align-items: stretch;
    flex-grow: 1;
  }
  .flex-center {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
@layer compositions {
  .grid-canvas {
    display: grid;
    max-height: 100%;
    height: 100%;
    & > * {
      min-height: 0;
    }
  }
  .grid-auto, .autogrid {
    --_autogrid-min-width: var(--autogrid-min-width, 200px);
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(var(--_autogrid-min-width), 1fr));
    grid-auto-rows: minmax(100px, auto);
  }
}
.split {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@property --gap {
  syntax: "<length>";
  inherits: false;
}
.vise, [class*="vise-"] {
  margin-left: auto;
  margin-right: auto;
}
@layer component {
  .window {
    display: grid;
    grid-template-rows: auto 1fr auto;
    & > * {
      min-height: 0;
    }
    .window__toolbar {
      display: flex;
      gap: var(--spacing-root);
      align-items: center;
    }
    .window__viewport {
      display: grid;
      overflow: auto;
      min-height: 0;
      max-height: 100%;
      grid-template-rows: 1fr;
      grid-template-columns: 1fr 1fr;
    }
  }
}
@layer component {
  .autoformat {
    h1 {
      margin-bottom: calc(var(--spacing) * 4);
      font-size: var(--text-3xl);
      line-height: var(--tw-leading, var(--text-3xl--line-height));
      letter-spacing: var(--tw-tracking, var(--text-3xl--letter-spacing));
      font-weight: var(--tw-font-weight, var(--text-3xl--font-weight));
      --tw-font-weight: var(--font-weight-bold);
      font-weight: var(--font-weight-bold);
      --font-weight: 700;
      --font-weight: 900;
    }
    h2 {
      margin-bottom: calc(var(--spacing) * 4);
      font-size: var(--text-2xl);
      line-height: var(--tw-leading, var(--text-2xl--line-height));
      font-weight: var(--tw-font-weight, var(--text-2xl--font-weight));
      --tw-font-weight: var(--font-weight-bold);
      font-weight: var(--font-weight-bold);
      --font-weight: 700;
      --font-weight: 900;
    }
    h3 {
      margin-bottom: calc(var(--spacing) * 4);
      font-size: var(--text-lg);
      line-height: var(--tw-leading, var(--text-lg--line-height));
      font-weight: var(--tw-font-weight, var(--text-lg--font-weight));
      --tw-font-weight: var(--font-weight-bold);
      font-weight: var(--font-weight-bold);
      --font-weight: 700;
      --font-weight: 500;
    }
  }
}
@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    :root, :host {
      --font-weight: 400;
      --font-casual: 1;
    }
    *, ::before, ::after, ::backdrop {
      --tw-space-y-reverse: 0;
      --tw-border-style: solid;
      --tw-font-weight: initial;
      --gap: initial;
    }
  }
}
