/* ============================================================
 * app.css - generated by scripts/build-app-css.py
 *
 * Single consolidated stylesheet for the static playground. One
 * Tailwind version, deduped chrome / theme blocks, only the tool
 * CSS we actually use (bullets, CodeMirror, sideboard).
 *
 * Do not edit by hand - re-run the build script instead.
 * ============================================================ */

/* ---------- Tailwind 4.2.2 (utilities, base) — from LFC archive ---------- */
/*   source: extracted/local-first-conf-patchwork-release/styles/05-tailwind-4.2.2.css */
/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties {
  @supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
    *, :before, :after, ::backdrop {
      --tw-space-y-reverse: 0;
      --tw-border-style: solid;
      --tw-font-weight: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
    }
  }
}

@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: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --color-blue-400: oklch(70.7% .165 254.624);
    --color-gray-200: oklch(92.8% .006 264.531);
    --color-gray-300: oklch(87.2% .01 258.338);
    --color-gray-400: oklch(70.7% .022 261.325);
    --color-gray-800: oklch(27.8% .033 256.848);
    --color-white: #fff;
    --spacing: .25rem;
    --text-xs: .75rem;
    --text-xs--line-height: calc(1 / .75);
    --text-sm: .875rem;
    --text-sm--line-height: calc(1.25 / .875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --font-weight-medium: 500;
    --radius-lg: .5rem;
    --default-transition-duration: .15s;
    --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
  }
}

@layer base {
  *, :after, :before, ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  ::file-selector-button {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  html, :host {
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    line-height: 1.5;
    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;
    -webkit-text-decoration: 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 {
    vertical-align: baseline;
    font-size: 75%;
    line-height: 0;
    position: relative;
  }

  sub {
    bottom: -.25em;
  }

  sup {
    top: -.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 {
    vertical-align: middle;
    display: block;
  }

  img, video {
    max-width: 100%;
    height: auto;
  }

  button, input, select, optgroup, textarea {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  :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)) {
      ::placeholder {
        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 {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-year-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-month-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-day-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-hour-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-minute-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-second-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-millisecond-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }

  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }

  :-moz-ui-invalid {
    box-shadow: none;
  }

  button, input:where([type="button"], [type="reset"], [type="submit"]) {
    appearance: button;
  }

  ::file-selector-button {
    appearance: button;
  }

  ::-webkit-inner-spin-button {
    height: auto;
  }

  ::-webkit-outer-spin-button {
    height: auto;
  }

  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }

  :where(:root), :root:has(input.theme-controller[value="light"]:checked), [data-theme="light"] {
    color-scheme: light;
    --color-base-100: oklch(100% 0 0);
    --color-base-200: oklch(98% 0 0);
    --color-base-300: oklch(95% 0 0);
    --color-base-content: oklch(21% .006 285.885);
    --color-primary: oklch(45% .24 277.023);
    --color-primary-content: oklch(93% .034 272.788);
    --color-secondary: oklch(65% .241 354.308);
    --color-secondary-content: oklch(94% .028 342.258);
    --color-accent: oklch(77% .152 181.912);
    --color-accent-content: oklch(38% .063 188.416);
    --color-neutral: oklch(14% .005 285.823);
    --color-neutral-content: oklch(92% .004 286.32);
    --color-info: oklch(74% .16 232.661);
    --color-info-content: oklch(29% .066 243.157);
    --color-success: oklch(76% .177 163.223);
    --color-success-content: oklch(37% .077 168.94);
    --color-warning: oklch(82% .189 84.429);
    --color-warning-content: oklch(41% .112 45.904);
    --color-error: oklch(71% .194 13.428);
    --color-error-content: oklch(27% .105 12.094);
    --radius-selector: .5rem;
    --radius-field: .25rem;
    --radius-box: .5rem;
    --size-selector: .25rem;
    --size-field: .25rem;
    --border: 1px;
    --depth: 1;
    --noise: 0;
  }

  @media (prefers-color-scheme: dark) {
    :root:not([data-theme]) {
      color-scheme: dark;
      --color-base-100: oklch(25.33% .016 252.42);
      --color-base-200: oklch(23.26% .014 253.1);
      --color-base-300: oklch(21.15% .012 254.09);
      --color-base-content: oklch(97.807% .029 256.847);
      --color-primary: oklch(58% .233 277.117);
      --color-primary-content: oklch(96% .018 272.314);
      --color-secondary: oklch(65% .241 354.308);
      --color-secondary-content: oklch(94% .028 342.258);
      --color-accent: oklch(77% .152 181.912);
      --color-accent-content: oklch(38% .063 188.416);
      --color-neutral: oklch(14% .005 285.823);
      --color-neutral-content: oklch(92% .004 286.32);
      --color-info: oklch(74% .16 232.661);
      --color-info-content: oklch(29% .066 243.157);
      --color-success: oklch(76% .177 163.223);
      --color-success-content: oklch(37% .077 168.94);
      --color-warning: oklch(82% .189 84.429);
      --color-warning-content: oklch(41% .112 45.904);
      --color-error: oklch(71% .194 13.428);
      --color-error-content: oklch(27% .105 12.094);
      --radius-selector: .5rem;
      --radius-field: .25rem;
      --radius-box: .5rem;
      --size-selector: .25rem;
      --size-field: .25rem;
      --border: 1px;
      --depth: 1;
      --noise: 0;
    }
  }

  :root:has(input.theme-controller[value="light"]:checked), [data-theme="light"] {
    color-scheme: light;
    --color-base-100: oklch(100% 0 0);
    --color-base-200: oklch(98% 0 0);
    --color-base-300: oklch(95% 0 0);
    --color-base-content: oklch(21% .006 285.885);
    --color-primary: oklch(45% .24 277.023);
    --color-primary-content: oklch(93% .034 272.788);
    --color-secondary: oklch(65% .241 354.308);
    --color-secondary-content: oklch(94% .028 342.258);
    --color-accent: oklch(77% .152 181.912);
    --color-accent-content: oklch(38% .063 188.416);
    --color-neutral: oklch(14% .005 285.823);
    --color-neutral-content: oklch(92% .004 286.32);
    --color-info: oklch(74% .16 232.661);
    --color-info-content: oklch(29% .066 243.157);
    --color-success: oklch(76% .177 163.223);
    --color-success-content: oklch(37% .077 168.94);
    --color-warning: oklch(82% .189 84.429);
    --color-warning-content: oklch(41% .112 45.904);
    --color-error: oklch(71% .194 13.428);
    --color-error-content: oklch(27% .105 12.094);
    --radius-selector: .5rem;
    --radius-field: .25rem;
    --radius-box: .5rem;
    --size-selector: .25rem;
    --size-field: .25rem;
    --border: 1px;
    --depth: 1;
    --noise: 0;
  }

  :root:has(input.theme-controller[value="dark"]:checked), [data-theme="dark"] {
    color-scheme: dark;
    --color-base-100: oklch(25.33% .016 252.42);
    --color-base-200: oklch(23.26% .014 253.1);
    --color-base-300: oklch(21.15% .012 254.09);
    --color-base-content: oklch(97.807% .029 256.847);
    --color-primary: oklch(58% .233 277.117);
    --color-primary-content: oklch(96% .018 272.314);
    --color-secondary: oklch(65% .241 354.308);
    --color-secondary-content: oklch(94% .028 342.258);
    --color-accent: oklch(77% .152 181.912);
    --color-accent-content: oklch(38% .063 188.416);
    --color-neutral: oklch(14% .005 285.823);
    --color-neutral-content: oklch(92% .004 286.32);
    --color-info: oklch(74% .16 232.661);
    --color-info-content: oklch(29% .066 243.157);
    --color-success: oklch(76% .177 163.223);
    --color-success-content: oklch(37% .077 168.94);
    --color-warning: oklch(82% .189 84.429);
    --color-warning-content: oklch(41% .112 45.904);
    --color-error: oklch(71% .194 13.428);
    --color-error-content: oklch(27% .105 12.094);
    --radius-selector: .5rem;
    --radius-field: .25rem;
    --radius-box: .5rem;
    --size-selector: .25rem;
    --size-field: .25rem;
    --border: 1px;
    --depth: 1;
    --noise: 0;
  }

  :root {
    --fx-noise: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.34' numOctaves='4' stitchTiles='stitch'%3E%3C/feTurbulence%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23a)' opacity='0.2'%3E%3C/rect%3E%3C/svg%3E");
    scrollbar-color: currentColor #0000;
  }

  @supports (color: color-mix(in lab, red, red)) {
    :root {
      scrollbar-color: color-mix(in oklch, currentColor 35%, #0000) #0000;
    }
  }

  @property --radialprogress {
    syntax: "<percentage>";
    inherits: true;
    initial-value: 0%;
  }

  :root:not(span) {
    overflow: var(--page-overflow);
  }

  :root {
    background: var(--page-scroll-bg, var(--root-bg));
    --page-scroll-bg-on: linear-gradient(var(--root-bg, #0000), var(--root-bg, #0000))
    var(--root-bg, #0000);
  }

  @supports (color: color-mix(in lab, red, red)) {
    :root {
      --page-scroll-bg-on: linear-gradient(var(--root-bg, #0000), var(--root-bg, #0000))
    color-mix(in srgb, var(--root-bg, #0000), oklch(0% 0 0) calc(var(--page-has-backdrop, 0) * 40%));
    }
  }

  :root {
    --page-scroll-transition-on: background-color .3s ease-out;
    transition: var(--page-scroll-transition);
    scrollbar-gutter: var(--page-scroll-gutter, unset);
    scrollbar-gutter: if(style(--page-has-scroll: 1): var(--page-scroll-gutter, unset) ; else: unset);
  }

  @keyframes set-page-has-scroll {
    0%, to {
      --page-has-scroll: 1;
    }
  }

  :root, [data-theme] {
    background: var(--page-scroll-bg, var(--root-bg));
    color: var(--color-base-content);
  }

  :where(:root, [data-theme]) {
    --root-bg: var(--color-base-100);
  }
}

@layer components;

@layer utilities {
  @layer daisyui.l1.l2.l3 {
    .diff {
      webkit-user-select: none;
      -webkit-user-select: none;
      user-select: none;
      direction: ltr;
      grid-template-rows: 1fr 1.8rem 1fr;
      grid-template-columns: auto 1fr;
      width: 100%;
      display: grid;
      position: relative;
      overflow: hidden;
      container-type: inline-size;
    }

    .diff:focus-visible, .diff:has(.diff-item-1:focus-visible), .diff:focus-visible {
      outline-style: var(--tw-outline-style);
      outline-offset: 1px;
      outline-width: 2px;
      outline-color: var(--color-base-content);
    }

    .diff:focus-visible .diff-resizer {
      min-width: 95cqi;
      max-width: 95cqi;
    }

    .diff:has(.diff-item-1:focus-visible) {
      outline-style: var(--tw-outline-style);
      outline-offset: 1px;
      outline-width: 2px;
    }

    .diff:has(.diff-item-1:focus-visible) .diff-resizer {
      min-width: 5cqi;
      max-width: 5cqi;
    }

    @supports (-webkit-overflow-scrolling: touch) and (overflow: -webkit-paged-x) {
      .diff:focus .diff-resizer {
        min-width: 5cqi;
        max-width: 5cqi;
      }

      .diff:has(.diff-item-1:focus) .diff-resizer {
        min-width: 95cqi;
        max-width: 95cqi;
      }
    }

    :where(.btn) {
      width: unset;
    }

    .btn {
      cursor: pointer;
      text-align: center;
      vertical-align: middle;
      outline-offset: 2px;
      webkit-user-select: none;
      -webkit-user-select: none;
      user-select: none;
      padding-inline: var(--btn-p);
      color: var(--btn-fg);
      --tw-prose-links: var(--btn-fg);
      height: var(--size);
      font-size: var(--fontsize, .875rem);
      outline-color: var(--btn-color, var(--color-base-content));
      background-color: var(--btn-bg);
      background-size: auto, calc(var(--noise) * 100%);
      background-image: none, var(--btn-noise);
      border-width: var(--border);
      border-style: solid;
      border-color: var(--btn-border);
      text-shadow: 0 .5px oklch(100% 0 0 / calc(var(--depth) * .15));
      touch-action: manipulation;
      box-shadow: 0 .5px 0 .5px oklch(100% 0 0 / calc(var(--depth) * 6%)) inset, var(--btn-shadow);
      --size: calc(var(--size-field, .25rem) * 10);
      --btn-bg: var(--btn-color, var(--color-base-200));
      --btn-fg: var(--color-base-content);
      --btn-p: 1rem;
      --btn-border: var(--btn-bg);
      border-start-start-radius: var(--join-ss, var(--radius-field));
      border-start-end-radius: var(--join-se, var(--radius-field));
      border-end-end-radius: var(--join-ee, var(--radius-field));
      border-end-start-radius: var(--join-es, var(--radius-field));
      flex-wrap: nowrap;
      flex-shrink: 0;
      justify-content: center;
      align-items: center;
      gap: .375rem;
      font-weight: 600;
      transition-property: color, background-color, border-color, box-shadow;
      transition-duration: .2s;
      transition-timing-function: cubic-bezier(0, 0, .2, 1);
      display: inline-flex;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn {
        --btn-border: color-mix(in oklab, var(--btn-bg), #000 calc(var(--depth) * 5%));
      }
    }

    .btn {
      --btn-shadow: 0 3px 2px -2px var(--btn-bg),
      0 4px 3px -2px var(--btn-bg);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn {
        --btn-shadow: 0 3px 2px -2px color-mix(in oklab, var(--btn-bg) calc(var(--depth) * 30%), #0000),
      0 4px 3px -2px color-mix(in oklab, var(--btn-bg) calc(var(--depth) * 30%), #0000);
      }
    }

    .btn {
      --btn-noise: var(--fx-noise);
    }

    @media (hover: hover) {
      .btn:hover {
        --btn-bg: var(--btn-color, var(--color-base-200));
      }

      @supports (color: color-mix(in lab, red, red)) {
        .btn:hover {
          --btn-bg: color-mix(in oklab, var(--btn-color, var(--color-base-200)), #000 7%);
        }
      }
    }

    .btn:focus-visible, .btn:has(:focus-visible) {
      isolation: isolate;
      outline-width: 2px;
      outline-style: solid;
    }

    .btn:active:not(.btn-active) {
      --btn-bg: var(--btn-color, var(--color-base-200));
      translate: 0 .5px;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn:active:not(.btn-active) {
        --btn-bg: color-mix(in oklab, var(--btn-color, var(--color-base-200)), #000 5%);
      }
    }

    .btn:active:not(.btn-active) {
      --btn-border: var(--btn-color, var(--color-base-200));
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn:active:not(.btn-active) {
        --btn-border: color-mix(in oklab, var(--btn-color, var(--color-base-200)), #000 7%);
      }
    }

    .btn:active:not(.btn-active) {
      --btn-shadow: 0 0 0 0 oklch(0% 0 0 / 0), 0 0 0 0 oklch(0% 0 0 / 0);
    }

    .btn:is(input[type="checkbox"], input[type="radio"]) {
      appearance: none;
    }

    .btn:is(input[type="checkbox"], input[type="radio"])[aria-label]:after {
      --tw-content: attr(aria-label);
      content: var(--tw-content);
    }

    .btn:where(input:checked:not(.filter .btn)) {
      --btn-color: var(--color-primary);
      --btn-fg: var(--color-primary-content);
      isolation: isolate;
    }

    .input {
      cursor: text;
      border: var(--border) solid #0000;
      appearance: none;
      background-color: var(--color-base-100);
      vertical-align: middle;
      white-space: nowrap;
      width: clamp(3rem, 20rem, 100%);
      height: var(--size);
      font-size: max(var(--font-size, .875rem), .875rem);
      touch-action: manipulation;
      border-color: var(--input-color);
      box-shadow: 0 1px var(--input-color) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * .1)) inset;
      border-start-start-radius: var(--join-ss, var(--radius-field));
      border-start-end-radius: var(--join-se, var(--radius-field));
      border-end-end-radius: var(--join-ee, var(--radius-field));
      border-end-start-radius: var(--join-es, var(--radius-field));
      flex-shrink: 1;
      align-items: center;
      gap: .5rem;
      padding-inline: .75rem;
      display: inline-flex;
      position: relative;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .input {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * .1)) inset;
      }
    }

    .input {
      --size: calc(var(--size-field, .25rem) * 10);
      --input-color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .input {
        --input-color: color-mix(in oklab, var(--color-base-content) 20%, #0000);
      }
    }

    .input:where(input) {
      display: inline-flex;
    }

    .input :where(input) {
      appearance: none;
      background-color: #0000;
      border: none;
      width: 100%;
      height: 100%;
      display: inline-flex;
    }

    .input :where(input):focus, .input :where(input):focus-within {
      --tw-outline-style: none;
      outline-style: none;
    }

    @media (forced-colors: active) {
      .input :where(input):focus, .input :where(input):focus-within {
        outline-offset: 2px;
        outline: 2px solid #0000;
      }
    }

    .input :where(input[type="url"]), .input :where(input[type="email"]) {
      direction: ltr;
    }

    .input :where(input[type="date"]) {
      display: inline-flex;
    }

    .input:focus, .input:focus-within {
      --input-color: var(--color-base-content);
      box-shadow: 0 1px var(--input-color);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .input:focus, .input:focus-within {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000);
      }
    }

    .input:focus, .input:focus-within {
      outline: 2px solid var(--input-color);
      outline-offset: 2px;
      isolation: isolate;
    }

    @media (pointer: coarse) {
      @supports (-webkit-touch-callout: none) {
        .input:focus, .input:focus-within {
          --font-size: 1rem;
        }
      }
    }

    .input:has( > input[disabled]), .input:is(:disabled, [disabled]), fieldset:disabled .input {
      cursor: not-allowed;
      border-color: var(--color-base-200);
      background-color: var(--color-base-200);
      color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .input:has( > input[disabled]), .input:is(:disabled, [disabled]), fieldset:disabled .input {
        color: color-mix(in oklab, var(--color-base-content) 40%, transparent);
      }
    }

    :is(.input:has( > input[disabled]), .input:is(:disabled, [disabled]), fieldset:disabled .input)::placeholder {
      color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      :is(.input:has( > input[disabled]), .input:is(:disabled, [disabled]), fieldset:disabled .input)::placeholder {
        color: color-mix(in oklab, var(--color-base-content) 20%, transparent);
      }
    }

    .input:has( > input[disabled]), .input:is(:disabled, [disabled]), fieldset:disabled .input {
      box-shadow: none;
    }

    .input:has( > input[disabled]) > input[disabled] {
      cursor: not-allowed;
    }

    .input::-webkit-date-and-time-value {
      text-align: inherit;
    }

    .input[type="number"]::-webkit-inner-spin-button {
      margin-block: -.75rem;
      margin-inline-end: -.75rem;
    }

    .input::-webkit-calendar-picker-indicator {
      position: absolute;
      inset-inline-end: .75em;
    }

    .input:has( > input[type="date"]) :where(input[type="date"]) {
      webkit-appearance: none;
      appearance: none;
      display: inline-flex;
    }

    .input:has( > input[type="date"]) input[type="date"]::-webkit-calendar-picker-indicator {
      cursor: pointer;
      width: 1em;
      height: 1em;
      position: absolute;
      inset-inline-end: .75em;
    }

    .card {
      border-radius: var(--radius-box);
      outline-offset: 2px;
      outline: 0 solid #0000;
      flex-direction: column;
      transition: outline .2s ease-in-out;
      display: flex;
      position: relative;
    }

    .card:focus {
      --tw-outline-style: none;
      outline-style: none;
    }

    @media (forced-colors: active) {
      .card:focus {
        outline-offset: 2px;
        outline: 2px solid #0000;
      }
    }

    .card:focus-visible {
      outline-color: currentColor;
    }

    .card :where(figure:first-child) {
      border-start-start-radius: inherit;
      border-start-end-radius: inherit;
      border-end-end-radius: unset;
      border-end-start-radius: unset;
      overflow: hidden;
    }

    .card :where(figure:last-child) {
      border-start-start-radius: unset;
      border-start-end-radius: unset;
      border-end-end-radius: inherit;
      border-end-start-radius: inherit;
      overflow: hidden;
    }

    .card figure {
      justify-content: center;
      align-items: center;
      display: flex;
    }

    .card:has( > input:is(input[type="checkbox"], input[type="radio"])) {
      cursor: pointer;
      -webkit-user-select: none;
      user-select: none;
    }

    .card:has( > :checked) {
      outline: 2px solid;
    }

    .textarea {
      border: var(--border) solid #0000;
      appearance: none;
      border-radius: var(--radius-field);
      background-color: var(--color-base-100);
      vertical-align: middle;
      width: clamp(3rem, 20rem, 100%);
      min-height: 5rem;
      font-size: max(var(--font-size, .875rem), .875rem);
      touch-action: manipulation;
      border-color: var(--input-color);
      box-shadow: 0 1px var(--input-color) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * .1)) inset;
      flex-shrink: 1;
      padding-block: .5rem;
      padding-inline: .75rem;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .textarea {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * .1)) inset;
      }
    }

    .textarea {
      --input-color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .textarea {
        --input-color: color-mix(in oklab, var(--color-base-content) 20%, #0000);
      }
    }

    .textarea textarea {
      appearance: none;
      background-color: #0000;
      border: none;
    }

    .textarea textarea:focus, .textarea textarea:focus-within {
      --tw-outline-style: none;
      outline-style: none;
    }

    @media (forced-colors: active) {
      .textarea textarea:focus, .textarea textarea:focus-within {
        outline-offset: 2px;
        outline: 2px solid #0000;
      }
    }

    .textarea:focus, .textarea:focus-within {
      --input-color: var(--color-base-content);
      box-shadow: 0 1px var(--input-color);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .textarea:focus, .textarea:focus-within {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000);
      }
    }

    .textarea:focus, .textarea:focus-within {
      outline: 2px solid var(--input-color);
      outline-offset: 2px;
      isolation: isolate;
    }

    @media (pointer: coarse) {
      @supports (-webkit-touch-callout: none) {
        .textarea:focus, .textarea:focus-within {
          --font-size: 1rem;
        }
      }
    }

    .textarea:has( > textarea[disabled]), .textarea:is(:disabled, [disabled]) {
      cursor: not-allowed;
      border-color: var(--color-base-200);
      background-color: var(--color-base-200);
      color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .textarea:has( > textarea[disabled]), .textarea:is(:disabled, [disabled]) {
        color: color-mix(in oklab, var(--color-base-content) 40%, transparent);
      }
    }

    :is(.textarea:has( > textarea[disabled]), .textarea:is(:disabled, [disabled]))::placeholder {
      color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      :is(.textarea:has( > textarea[disabled]), .textarea:is(:disabled, [disabled]))::placeholder {
        color: color-mix(in oklab, var(--color-base-content) 20%, transparent);
      }
    }

    .textarea:has( > textarea[disabled]), .textarea:is(:disabled, [disabled]) {
      box-shadow: none;
    }

    .textarea:has( > textarea[disabled]) > textarea[disabled] {
      cursor: not-allowed;
    }

    .card-body {
      padding: var(--card-p, 1.5rem);
      font-size: var(--card-fs, .875rem);
      flex-direction: column;
      flex: auto;
      gap: .5rem;
      display: flex;
    }

    .card-body :where(p) {
      flex-grow: 1;
    }
  }

  .prose :where(a.btn:not(.btn-link)):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    text-decoration-line: none;
  }

  @layer daisyui.l1.l2 {
    .btn:disabled:not(.btn-link, .btn-ghost) {
      background-color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn:disabled:not(.btn-link, .btn-ghost) {
        background-color: color-mix(in oklab, var(--color-base-content) 10%, transparent);
      }
    }

    .btn:disabled:not(.btn-link, .btn-ghost) {
      box-shadow: none;
    }

    .btn:disabled {
      pointer-events: none;
      --btn-border: #0000;
      --btn-noise: none;
      --btn-fg: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn:disabled {
        --btn-fg: color-mix(in oklch, var(--color-base-content) 20%, #0000);
      }
    }

    .btn[disabled]:not(.btn-link, .btn-ghost) {
      background-color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn[disabled]:not(.btn-link, .btn-ghost) {
        background-color: color-mix(in oklab, var(--color-base-content) 10%, transparent);
      }
    }

    .btn[disabled]:not(.btn-link, .btn-ghost) {
      box-shadow: none;
    }

    .btn[disabled] {
      pointer-events: none;
      --btn-border: #0000;
      --btn-noise: none;
      --btn-fg: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn[disabled] {
        --btn-fg: color-mix(in oklch, var(--color-base-content) 20%, #0000);
      }
    }

    .btn-sm {
      --fontsize: .75rem;
      --btn-p: .75rem;
      --size: calc(var(--size-field, .25rem) * 8);
    }
  }

  .flex {
    display: flex;
  }

  .h-full {
    height: 100%;
  }

  .min-h-24 {
    min-height: calc(var(--spacing) * 24);
  }

  .w-full {
    width: 100%;
  }

  .cursor-pointer {
    cursor: pointer;
  }

  .flex-col {
    flex-direction: column;
  }

  .items-center {
    align-items: center;
  }

  .justify-between {
    justify-content: space-between;
  }

  .justify-end {
    justify-content: flex-end;
  }

  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }

  :where(.space-y-2 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
  }

  .rounded-lg {
    border-radius: var(--radius-lg);
  }

  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }

  .border-blue-400 {
    border-color: var(--color-blue-400);
  }

  .border-gray-200 {
    border-color: var(--color-gray-200);
  }

  .border-gray-300 {
    border-color: var(--color-gray-300);
  }

  .bg-white {
    background-color: var(--color-white);
  }

  .p-2 {
    padding: calc(var(--spacing) * 2);
  }

  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }

  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }

  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }

  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }

  .whitespace-nowrap {
    white-space: nowrap;
  }

  .whitespace-pre-wrap {
    white-space: pre-wrap;
  }

  .text-gray-400 {
    color: var(--color-gray-400);
  }

  .text-gray-800 {
    color: var(--color-gray-800);
  }

  .shadow-md {
    --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, #0000001a), 0 2px 4px -2px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-sm {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  @layer daisyui.l1 {
    .btn-ghost:not(.btn-active, :hover, :active:focus, :focus-visible, input:checked:not(.filter .btn)) {
      --btn-shadow: "";
      --btn-bg: #0000;
      --btn-border: #0000;
      --btn-noise: none;
    }

    .btn-ghost:not(.btn-active, :hover, :active:focus, :focus-visible, input:checked:not(.filter .btn)):not(:disabled, [disabled], .btn-disabled) {
      --btn-fg: var(--btn-color, currentColor);
      outline-color: currentColor;
    }

    @media (hover: none) {
      .btn-ghost:not(.btn-active, :active, :focus-visible, input:checked:not(.filter .btn)):hover {
        --btn-shadow: "";
        --btn-bg: #0000;
        --btn-fg: var(--btn-color, currentColor);
        --btn-border: #0000;
        --btn-noise: none;
        outline-color: currentColor;
      }
    }
  }

  .transition-shadow {
    transition-property: box-shadow;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  @media (hover: hover) {
    .hover\:shadow-md:hover {
      --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, #0000001a), 0 2px 4px -2px var(--tw-shadow-color, #0000001a);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
}

@keyframes rating {
  0%, 40% {
    filter: brightness(1.05) contrast(1.05);
    scale: 1.1;
  }
}

@keyframes dropdown {
  0% {
    opacity: 0;
  }
}

@keyframes radio {
  0% {
    padding: 5px;
  }

  50% {
    padding: 3px;
  }
}

@keyframes toast {
  0% {
    opacity: 0;
    scale: .9;
  }

  100% {
    opacity: 1;
    scale: 1;
  }
}

@keyframes rotator {
  89.9999%, 100% {
    --first-item-position: 0 0%;
  }

  90%, 99.9999% {
    --first-item-position: 0 calc(var(--items) * 100%);
  }

  100% {
    translate: 0 -100%;
  }
}

@keyframes skeleton {
  0% {
    background-position: 150%;
  }

  100% {
    background-position: -50%;
  }
}

@keyframes menu {
  0% {
    opacity: 0;
  }
}

@keyframes progress {
  50% {
    background-position-x: -115%;
  }
}

@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
}

@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-ring-color {
  syntax: "*";
  inherits: false
}

@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false
}

@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-ring-inset {
  syntax: "*";
  inherits: false
}

@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0;
}

@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}

@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

/* ---------- Tailwind 4.2.2 (more utilities) — from LFC archive ---------- */
/*   source: extracted/local-first-conf-patchwork-release/styles/08-tailwind-4.2.2-2.css */
/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties {
  @supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
    *, :before, :after, ::backdrop {
      --tw-space-y-reverse: 0;
      --tw-border-style: solid;
      --tw-font-weight: initial;
      --tw-tracking: initial;
    }
  }
}

@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: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --color-black: #000;
    --spacing: .25rem;
    --text-xs: .75rem;
    --text-xs--line-height: calc(1 / .75);
    --text-sm: .875rem;
    --text-sm--line-height: calc(1.25 / .875);
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --tracking-wide: .025em;
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
  }
}

@layer base {
  *, :after, :before, ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  ::file-selector-button {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  html, :host {
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    line-height: 1.5;
    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;
    -webkit-text-decoration: 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 {
    vertical-align: baseline;
    font-size: 75%;
    line-height: 0;
    position: relative;
  }

  sub {
    bottom: -.25em;
  }

  sup {
    top: -.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 {
    vertical-align: middle;
    display: block;
  }

  img, video {
    max-width: 100%;
    height: auto;
  }

  button, input, select, optgroup, textarea {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  :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)) {
      ::placeholder {
        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 {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-year-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-month-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-day-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-hour-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-minute-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-second-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-millisecond-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }

  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }

  :-moz-ui-invalid {
    box-shadow: none;
  }

  button, input:where([type="button"], [type="reset"], [type="submit"]) {
    appearance: button;
  }

  ::file-selector-button {
    appearance: button;
  }

  ::-webkit-inner-spin-button {
    height: auto;
  }

  ::-webkit-outer-spin-button {
    height: auto;
  }

  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }

  :where(:root), :root:has(input.theme-controller[value="light"]:checked), [data-theme="light"] {
    color-scheme: light;
    --color-base-100: oklch(100% 0 0);
    --color-base-200: oklch(98% 0 0);
    --color-base-300: oklch(95% 0 0);
    --color-base-content: oklch(21% .006 285.885);
    --color-primary: oklch(45% .24 277.023);
    --color-primary-content: oklch(93% .034 272.788);
    --color-secondary: oklch(65% .241 354.308);
    --color-secondary-content: oklch(94% .028 342.258);
    --color-accent: oklch(77% .152 181.912);
    --color-accent-content: oklch(38% .063 188.416);
    --color-neutral: oklch(14% .005 285.823);
    --color-neutral-content: oklch(92% .004 286.32);
    --color-info: oklch(74% .16 232.661);
    --color-info-content: oklch(29% .066 243.157);
    --color-success: oklch(76% .177 163.223);
    --color-success-content: oklch(37% .077 168.94);
    --color-warning: oklch(82% .189 84.429);
    --color-warning-content: oklch(41% .112 45.904);
    --color-error: oklch(71% .194 13.428);
    --color-error-content: oklch(27% .105 12.094);
    --radius-selector: .5rem;
    --radius-field: .25rem;
    --radius-box: .5rem;
    --size-selector: .25rem;
    --size-field: .25rem;
    --border: 1px;
    --depth: 1;
    --noise: 0;
  }

  @media (prefers-color-scheme: dark) {
    :root:not([data-theme]) {
      color-scheme: dark;
      --color-base-100: oklch(25.33% .016 252.42);
      --color-base-200: oklch(23.26% .014 253.1);
      --color-base-300: oklch(21.15% .012 254.09);
      --color-base-content: oklch(97.807% .029 256.847);
      --color-primary: oklch(58% .233 277.117);
      --color-primary-content: oklch(96% .018 272.314);
      --color-secondary: oklch(65% .241 354.308);
      --color-secondary-content: oklch(94% .028 342.258);
      --color-accent: oklch(77% .152 181.912);
      --color-accent-content: oklch(38% .063 188.416);
      --color-neutral: oklch(14% .005 285.823);
      --color-neutral-content: oklch(92% .004 286.32);
      --color-info: oklch(74% .16 232.661);
      --color-info-content: oklch(29% .066 243.157);
      --color-success: oklch(76% .177 163.223);
      --color-success-content: oklch(37% .077 168.94);
      --color-warning: oklch(82% .189 84.429);
      --color-warning-content: oklch(41% .112 45.904);
      --color-error: oklch(71% .194 13.428);
      --color-error-content: oklch(27% .105 12.094);
      --radius-selector: .5rem;
      --radius-field: .25rem;
      --radius-box: .5rem;
      --size-selector: .25rem;
      --size-field: .25rem;
      --border: 1px;
      --depth: 1;
      --noise: 0;
    }
  }

  :root:has(input.theme-controller[value="light"]:checked), [data-theme="light"] {
    color-scheme: light;
    --color-base-100: oklch(100% 0 0);
    --color-base-200: oklch(98% 0 0);
    --color-base-300: oklch(95% 0 0);
    --color-base-content: oklch(21% .006 285.885);
    --color-primary: oklch(45% .24 277.023);
    --color-primary-content: oklch(93% .034 272.788);
    --color-secondary: oklch(65% .241 354.308);
    --color-secondary-content: oklch(94% .028 342.258);
    --color-accent: oklch(77% .152 181.912);
    --color-accent-content: oklch(38% .063 188.416);
    --color-neutral: oklch(14% .005 285.823);
    --color-neutral-content: oklch(92% .004 286.32);
    --color-info: oklch(74% .16 232.661);
    --color-info-content: oklch(29% .066 243.157);
    --color-success: oklch(76% .177 163.223);
    --color-success-content: oklch(37% .077 168.94);
    --color-warning: oklch(82% .189 84.429);
    --color-warning-content: oklch(41% .112 45.904);
    --color-error: oklch(71% .194 13.428);
    --color-error-content: oklch(27% .105 12.094);
    --radius-selector: .5rem;
    --radius-field: .25rem;
    --radius-box: .5rem;
    --size-selector: .25rem;
    --size-field: .25rem;
    --border: 1px;
    --depth: 1;
    --noise: 0;
  }

  :root:has(input.theme-controller[value="dark"]:checked), [data-theme="dark"] {
    color-scheme: dark;
    --color-base-100: oklch(25.33% .016 252.42);
    --color-base-200: oklch(23.26% .014 253.1);
    --color-base-300: oklch(21.15% .012 254.09);
    --color-base-content: oklch(97.807% .029 256.847);
    --color-primary: oklch(58% .233 277.117);
    --color-primary-content: oklch(96% .018 272.314);
    --color-secondary: oklch(65% .241 354.308);
    --color-secondary-content: oklch(94% .028 342.258);
    --color-accent: oklch(77% .152 181.912);
    --color-accent-content: oklch(38% .063 188.416);
    --color-neutral: oklch(14% .005 285.823);
    --color-neutral-content: oklch(92% .004 286.32);
    --color-info: oklch(74% .16 232.661);
    --color-info-content: oklch(29% .066 243.157);
    --color-success: oklch(76% .177 163.223);
    --color-success-content: oklch(37% .077 168.94);
    --color-warning: oklch(82% .189 84.429);
    --color-warning-content: oklch(41% .112 45.904);
    --color-error: oklch(71% .194 13.428);
    --color-error-content: oklch(27% .105 12.094);
    --radius-selector: .5rem;
    --radius-field: .25rem;
    --radius-box: .5rem;
    --size-selector: .25rem;
    --size-field: .25rem;
    --border: 1px;
    --depth: 1;
    --noise: 0;
  }

  :root {
    --fx-noise: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.34' numOctaves='4' stitchTiles='stitch'%3E%3C/feTurbulence%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23a)' opacity='0.2'%3E%3C/rect%3E%3C/svg%3E");
    scrollbar-color: currentColor #0000;
  }

  @supports (color: color-mix(in lab, red, red)) {
    :root {
      scrollbar-color: color-mix(in oklch, currentColor 35%, #0000) #0000;
    }
  }

  @property --radialprogress {
    syntax: "<percentage>";
    inherits: true;
    initial-value: 0%;
  }

  :root:not(span) {
    overflow: var(--page-overflow);
  }

  :root {
    background: var(--page-scroll-bg, var(--root-bg));
    --page-scroll-bg-on: linear-gradient(var(--root-bg, #0000), var(--root-bg, #0000))
    var(--root-bg, #0000);
  }

  @supports (color: color-mix(in lab, red, red)) {
    :root {
      --page-scroll-bg-on: linear-gradient(var(--root-bg, #0000), var(--root-bg, #0000))
    color-mix(in srgb, var(--root-bg, #0000), oklch(0% 0 0) calc(var(--page-has-backdrop, 0) * 40%));
    }
  }

  :root {
    --page-scroll-transition-on: background-color .3s ease-out;
    transition: var(--page-scroll-transition);
    scrollbar-gutter: var(--page-scroll-gutter, unset);
    scrollbar-gutter: if(style(--page-has-scroll: 1): var(--page-scroll-gutter, unset) ; else: unset);
  }

  @keyframes set-page-has-scroll {
    0%, to {
      --page-has-scroll: 1;
    }
  }

  :root, [data-theme] {
    background: var(--page-scroll-bg, var(--root-bg));
    color: var(--color-base-content);
  }

  :where(:root, [data-theme]) {
    --root-bg: var(--color-base-100);
  }
}

@layer components;

@layer utilities {
  @layer daisyui.l1.l2.l3 {
    .diff {
      webkit-user-select: none;
      -webkit-user-select: none;
      user-select: none;
      direction: ltr;
      grid-template-rows: 1fr 1.8rem 1fr;
      grid-template-columns: auto 1fr;
      width: 100%;
      display: grid;
      position: relative;
      overflow: hidden;
      container-type: inline-size;
    }

    .diff:focus-visible, .diff:has(.diff-item-1:focus-visible), .diff:focus-visible {
      outline-style: var(--tw-outline-style);
      outline-offset: 1px;
      outline-width: 2px;
      outline-color: var(--color-base-content);
    }

    .diff:focus-visible .diff-resizer {
      min-width: 95cqi;
      max-width: 95cqi;
    }

    .diff:has(.diff-item-1:focus-visible) {
      outline-style: var(--tw-outline-style);
      outline-offset: 1px;
      outline-width: 2px;
    }

    .diff:has(.diff-item-1:focus-visible) .diff-resizer {
      min-width: 5cqi;
      max-width: 5cqi;
    }

    @supports (-webkit-overflow-scrolling: touch) and (overflow: -webkit-paged-x) {
      .diff:focus .diff-resizer {
        min-width: 5cqi;
        max-width: 5cqi;
      }

      .diff:has(.diff-item-1:focus) .diff-resizer {
        min-width: 95cqi;
        max-width: 95cqi;
      }
    }

    :where(.btn) {
      width: unset;
    }

    .btn {
      cursor: pointer;
      text-align: center;
      vertical-align: middle;
      outline-offset: 2px;
      webkit-user-select: none;
      -webkit-user-select: none;
      user-select: none;
      padding-inline: var(--btn-p);
      color: var(--btn-fg);
      --tw-prose-links: var(--btn-fg);
      height: var(--size);
      font-size: var(--fontsize, .875rem);
      outline-color: var(--btn-color, var(--color-base-content));
      background-color: var(--btn-bg);
      background-size: auto, calc(var(--noise) * 100%);
      background-image: none, var(--btn-noise);
      border-width: var(--border);
      border-style: solid;
      border-color: var(--btn-border);
      text-shadow: 0 .5px oklch(100% 0 0 / calc(var(--depth) * .15));
      touch-action: manipulation;
      box-shadow: 0 .5px 0 .5px oklch(100% 0 0 / calc(var(--depth) * 6%)) inset, var(--btn-shadow);
      --size: calc(var(--size-field, .25rem) * 10);
      --btn-bg: var(--btn-color, var(--color-base-200));
      --btn-fg: var(--color-base-content);
      --btn-p: 1rem;
      --btn-border: var(--btn-bg);
      border-start-start-radius: var(--join-ss, var(--radius-field));
      border-start-end-radius: var(--join-se, var(--radius-field));
      border-end-end-radius: var(--join-ee, var(--radius-field));
      border-end-start-radius: var(--join-es, var(--radius-field));
      flex-wrap: nowrap;
      flex-shrink: 0;
      justify-content: center;
      align-items: center;
      gap: .375rem;
      font-weight: 600;
      transition-property: color, background-color, border-color, box-shadow;
      transition-duration: .2s;
      transition-timing-function: cubic-bezier(0, 0, .2, 1);
      display: inline-flex;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn {
        --btn-border: color-mix(in oklab, var(--btn-bg), #000 calc(var(--depth) * 5%));
      }
    }

    .btn {
      --btn-shadow: 0 3px 2px -2px var(--btn-bg),
      0 4px 3px -2px var(--btn-bg);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn {
        --btn-shadow: 0 3px 2px -2px color-mix(in oklab, var(--btn-bg) calc(var(--depth) * 30%), #0000),
      0 4px 3px -2px color-mix(in oklab, var(--btn-bg) calc(var(--depth) * 30%), #0000);
      }
    }

    .btn {
      --btn-noise: var(--fx-noise);
    }

    @media (hover: hover) {
      .btn:hover {
        --btn-bg: var(--btn-color, var(--color-base-200));
      }

      @supports (color: color-mix(in lab, red, red)) {
        .btn:hover {
          --btn-bg: color-mix(in oklab, var(--btn-color, var(--color-base-200)), #000 7%);
        }
      }
    }

    .btn:focus-visible, .btn:has(:focus-visible) {
      isolation: isolate;
      outline-width: 2px;
      outline-style: solid;
    }

    .btn:active:not(.btn-active) {
      --btn-bg: var(--btn-color, var(--color-base-200));
      translate: 0 .5px;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn:active:not(.btn-active) {
        --btn-bg: color-mix(in oklab, var(--btn-color, var(--color-base-200)), #000 5%);
      }
    }

    .btn:active:not(.btn-active) {
      --btn-border: var(--btn-color, var(--color-base-200));
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn:active:not(.btn-active) {
        --btn-border: color-mix(in oklab, var(--btn-color, var(--color-base-200)), #000 7%);
      }
    }

    .btn:active:not(.btn-active) {
      --btn-shadow: 0 0 0 0 oklch(0% 0 0 / 0), 0 0 0 0 oklch(0% 0 0 / 0);
    }

    .btn:is(input[type="checkbox"], input[type="radio"]) {
      appearance: none;
    }

    .btn:is(input[type="checkbox"], input[type="radio"])[aria-label]:after {
      --tw-content: attr(aria-label);
      content: var(--tw-content);
    }

    .btn:where(input:checked:not(.filter .btn)) {
      --btn-color: var(--color-primary);
      --btn-fg: var(--color-primary-content);
      isolation: isolate;
    }

    .loading {
      pointer-events: none;
      aspect-ratio: 1;
      vertical-align: middle;
      width: calc(var(--size-selector, .25rem) * 6);
      background-color: currentColor;
      display: inline-block;
      -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' stroke='black' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg transform-origin='center'%3E%3Ccircle cx='12' cy='12' r='9.5' fill='none' stroke-width='3' stroke-linecap='round'%3E%3CanimateTransform attributeName='transform' type='rotate' from='0 12 12' to='360 12 12' dur='2s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dasharray' values='0,150;42,150;42,150' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dashoffset' values='0;-16;-59' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3C/circle%3E%3C/g%3E%3C/svg%3E");
      mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' stroke='black' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg transform-origin='center'%3E%3Ccircle cx='12' cy='12' r='9.5' fill='none' stroke-width='3' stroke-linecap='round'%3E%3CanimateTransform attributeName='transform' type='rotate' from='0 12 12' to='360 12 12' dur='2s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dasharray' values='0,150;42,150;42,150' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dashoffset' values='0;-16;-59' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3C/circle%3E%3C/g%3E%3C/svg%3E");
      -webkit-mask-position: center;
      mask-position: center;
      -webkit-mask-size: 100%;
      mask-size: 100%;
      -webkit-mask-repeat: no-repeat;
      mask-repeat: no-repeat;
    }

    .list {
      flex-direction: column;
      font-size: .875rem;
      display: flex;
    }

    .list .list-row {
      --list-grid-cols: minmax(0, auto) 1fr;
      border-radius: var(--radius-box);
      word-break: break-word;
      grid-auto-flow: column;
      grid-template-columns: var(--list-grid-cols);
      gap: 1rem;
      padding: 1rem;
      display: grid;
      position: relative;
    }

    :is(.list > :not(:last-child).list-row, .list > :not(:last-child) .list-row):after {
      content: "";
      border-bottom: var(--border) solid;
      inset-inline: var(--radius-box);
      border-color: var(--color-base-content);
      position: absolute;
      bottom: 0;
    }

    @supports (color: color-mix(in lab, red, red)) {
      :is(.list > :not(:last-child).list-row, .list > :not(:last-child) .list-row):after {
        border-color: color-mix(in oklab, var(--color-base-content) 5%, transparent);
      }
    }

    .input {
      cursor: text;
      border: var(--border) solid #0000;
      appearance: none;
      background-color: var(--color-base-100);
      vertical-align: middle;
      white-space: nowrap;
      width: clamp(3rem, 20rem, 100%);
      height: var(--size);
      font-size: max(var(--font-size, .875rem), .875rem);
      touch-action: manipulation;
      border-color: var(--input-color);
      box-shadow: 0 1px var(--input-color) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * .1)) inset;
      border-start-start-radius: var(--join-ss, var(--radius-field));
      border-start-end-radius: var(--join-se, var(--radius-field));
      border-end-end-radius: var(--join-ee, var(--radius-field));
      border-end-start-radius: var(--join-es, var(--radius-field));
      flex-shrink: 1;
      align-items: center;
      gap: .5rem;
      padding-inline: .75rem;
      display: inline-flex;
      position: relative;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .input {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * .1)) inset;
      }
    }

    .input {
      --size: calc(var(--size-field, .25rem) * 10);
      --input-color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .input {
        --input-color: color-mix(in oklab, var(--color-base-content) 20%, #0000);
      }
    }

    .input:where(input) {
      display: inline-flex;
    }

    .input :where(input) {
      appearance: none;
      background-color: #0000;
      border: none;
      width: 100%;
      height: 100%;
      display: inline-flex;
    }

    .input :where(input):focus, .input :where(input):focus-within {
      --tw-outline-style: none;
      outline-style: none;
    }

    @media (forced-colors: active) {
      .input :where(input):focus, .input :where(input):focus-within {
        outline-offset: 2px;
        outline: 2px solid #0000;
      }
    }

    .input :where(input[type="url"]), .input :where(input[type="email"]) {
      direction: ltr;
    }

    .input :where(input[type="date"]) {
      display: inline-flex;
    }

    .input:focus, .input:focus-within {
      --input-color: var(--color-base-content);
      box-shadow: 0 1px var(--input-color);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .input:focus, .input:focus-within {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000);
      }
    }

    .input:focus, .input:focus-within {
      outline: 2px solid var(--input-color);
      outline-offset: 2px;
      isolation: isolate;
    }

    @media (pointer: coarse) {
      @supports (-webkit-touch-callout: none) {
        .input:focus, .input:focus-within {
          --font-size: 1rem;
        }
      }
    }

    .input:has( > input[disabled]), .input:is(:disabled, [disabled]), fieldset:disabled .input {
      cursor: not-allowed;
      border-color: var(--color-base-200);
      background-color: var(--color-base-200);
      color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .input:has( > input[disabled]), .input:is(:disabled, [disabled]), fieldset:disabled .input {
        color: color-mix(in oklab, var(--color-base-content) 40%, transparent);
      }
    }

    :is(.input:has( > input[disabled]), .input:is(:disabled, [disabled]), fieldset:disabled .input)::placeholder {
      color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      :is(.input:has( > input[disabled]), .input:is(:disabled, [disabled]), fieldset:disabled .input)::placeholder {
        color: color-mix(in oklab, var(--color-base-content) 20%, transparent);
      }
    }

    .input:has( > input[disabled]), .input:is(:disabled, [disabled]), fieldset:disabled .input {
      box-shadow: none;
    }

    .input:has( > input[disabled]) > input[disabled] {
      cursor: not-allowed;
    }

    .input::-webkit-date-and-time-value {
      text-align: inherit;
    }

    .input[type="number"]::-webkit-inner-spin-button {
      margin-block: -.75rem;
      margin-inline-end: -.75rem;
    }

    .input::-webkit-calendar-picker-indicator {
      position: absolute;
      inset-inline-end: .75em;
    }

    .input:has( > input[type="date"]) :where(input[type="date"]) {
      webkit-appearance: none;
      appearance: none;
      display: inline-flex;
    }

    .input:has( > input[type="date"]) input[type="date"]::-webkit-calendar-picker-indicator {
      cursor: pointer;
      width: 1em;
      height: 1em;
      position: absolute;
      inset-inline-end: .75em;
    }

    .select {
      border: var(--border) solid #0000;
      appearance: none;
      background-color: var(--color-base-100);
      vertical-align: middle;
      width: clamp(3rem, 20rem, 100%);
      height: var(--size);
      touch-action: manipulation;
      white-space: nowrap;
      text-overflow: ellipsis;
      box-shadow: 0 1px var(--input-color) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * .1)) inset;
      background-image: linear-gradient(45deg, #0000 50%, currentColor 50%), linear-gradient(135deg, currentColor 50%, #0000 50%);
      background-position: calc(100% - 20px) calc(1px + 50%), calc(100% - 16.1px) calc(1px + 50%);
      background-repeat: no-repeat;
      background-size: 4px 4px, 4px 4px;
      border-start-start-radius: var(--join-ss, var(--radius-field));
      border-start-end-radius: var(--join-se, var(--radius-field));
      border-end-end-radius: var(--join-ee, var(--radius-field));
      border-end-start-radius: var(--join-es, var(--radius-field));
      flex-shrink: 1;
      align-items: center;
      gap: .375rem;
      padding-inline: .75rem 1.75rem;
      font-size: .875rem;
      display: inline-flex;
      position: relative;
      overflow: hidden;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .select {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * .1)) inset;
      }
    }

    .select {
      border-color: var(--input-color);
      --input-color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .select {
        --input-color: color-mix(in oklab, var(--color-base-content) 20%, #0000);
      }
    }

    .select {
      --size: calc(var(--size-field, .25rem) * 10);
    }

    [dir="rtl"] .select {
      background-position: 12px calc(1px + 50%), 16px calc(1px + 50%);
    }

    [dir="rtl"] .select::picker(select) {
      translate: .5rem;
    }

    [dir="rtl"] .select select::picker(select) {
      translate: .5rem;
    }

    .select[multiple] {
      background-image: none;
      height: auto;
      padding-block: .75rem;
      padding-inline-end: .75rem;
      overflow: auto;
    }

    .select select {
      appearance: none;
      width: calc(100% + 2.75rem);
      height: calc(100% - calc(var(--border) * 2));
      background: inherit;
      border-radius: inherit;
      border-style: none;
      align-items: center;
      margin-inline: -.75rem -1.75rem;
      padding-inline: .75rem 1.75rem;
    }

    .select select:focus, .select select:focus-within {
      --tw-outline-style: none;
      outline-style: none;
    }

    @media (forced-colors: active) {
      .select select:focus, .select select:focus-within {
        outline-offset: 2px;
        outline: 2px solid #0000;
      }
    }

    .select select:not(:last-child) {
      background-image: none;
      margin-inline-end: -1.375rem;
    }

    .select:focus, .select:focus-within {
      --input-color: var(--color-base-content);
      box-shadow: 0 1px var(--input-color);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .select:focus, .select:focus-within {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000);
      }
    }

    .select:focus, .select:focus-within {
      outline: 2px solid var(--input-color);
      outline-offset: 2px;
      isolation: isolate;
    }

    .select:has( > select[disabled]), .select:is(:disabled, [disabled]), fieldset:disabled .select {
      cursor: not-allowed;
      border-color: var(--color-base-200);
      background-color: var(--color-base-200);
      color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .select:has( > select[disabled]), .select:is(:disabled, [disabled]), fieldset:disabled .select {
        color: color-mix(in oklab, var(--color-base-content) 40%, transparent);
      }
    }

    :is(.select:has( > select[disabled]), .select:is(:disabled, [disabled]), fieldset:disabled .select)::placeholder {
      color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      :is(.select:has( > select[disabled]), .select:is(:disabled, [disabled]), fieldset:disabled .select)::placeholder {
        color: color-mix(in oklab, var(--color-base-content) 20%, transparent);
      }
    }

    .select:has( > select[disabled]) > select[disabled] {
      cursor: not-allowed;
    }

    @supports (appearance: base-select) {
      .select, .select select {
        appearance: base-select;
      }

      :is(.select, .select select)::picker(select) {
        appearance: base-select;
      }
    }

    :is(.select, .select select)::picker(select) {
      color: inherit;
      border: var(--border) solid var(--color-base-200);
      border-radius: var(--radius-box);
      background-color: inherit;
      max-height: min(24rem, 70dvh);
      box-shadow: 0 2px calc(var(--depth) * 3px) -2px oklch(0% 0 0 / .2);
      box-shadow: 0 20px 25px -5px rgb(0 0 0 / calc(var(--depth) * .1)), 0 8px 10px -6px rgb(0 0 0 / calc(var(--depth) * .1));
      margin-block: .5rem;
      margin-inline: .5rem;
      padding: .5rem;
      translate: -.5rem;
    }

    :is(.select, .select select)::picker-icon {
      display: none;
    }

    :is(.select, .select select) optgroup {
      padding-top: .5em;
    }

    :is(.select, .select select) optgroup option:first-child {
      margin-top: .5em;
    }

    :is(.select, .select select) option {
      border-radius: var(--radius-field);
      white-space: normal;
      padding-block: .375rem;
      padding-inline: .75rem;
      transition-property: color, background-color;
      transition-duration: .2s;
      transition-timing-function: cubic-bezier(0, 0, .2, 1);
    }

    :is(.select, .select select) option:not(:disabled):hover, :is(.select, .select select) option:not(:disabled):focus-visible {
      cursor: pointer;
      background-color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      :is(.select, .select select) option:not(:disabled):hover, :is(.select, .select select) option:not(:disabled):focus-visible {
        background-color: color-mix(in oklab, var(--color-base-content) 10%, transparent);
      }
    }

    :is(.select, .select select) option:not(:disabled):hover, :is(.select, .select select) option:not(:disabled):focus-visible {
      --tw-outline-style: none;
      outline-style: none;
    }

    @media (forced-colors: active) {
      :is(.select, .select select) option:not(:disabled):hover, :is(.select, .select select) option:not(:disabled):focus-visible {
        outline-offset: 2px;
        outline: 2px solid #0000;
      }
    }

    :is(.select, .select select) option:not(:disabled):active {
      background-color: var(--color-neutral);
      color: var(--color-neutral-content);
      box-shadow: 0 2px calc(var(--depth) * 3px) -2px var(--color-neutral);
    }

    .timeline {
      display: flex;
      position: relative;
    }

    .timeline > li {
      grid-template-rows: var(--timeline-row-start, minmax(0, 1fr)) auto var(--timeline-row-end, minmax(0, 1fr));
      grid-template-columns: var(--timeline-col-start, minmax(0, 1fr)) auto var(--timeline-col-end, minmax(0, 1fr));
      flex-shrink: 0;
      align-items: center;
      display: grid;
      position: relative;
    }

    .timeline > li > hr {
      border: none;
      width: 100%;
    }

    .timeline > li > hr:first-child {
      grid-row-start: 2;
      grid-column-start: 1;
    }

    .timeline > li > hr:last-child {
      grid-area: 2 / 3 / auto / none;
    }

    @media print {
      .timeline > li > hr {
        border: .1px solid var(--color-base-300);
      }
    }

    .timeline :where(hr) {
      background-color: var(--color-base-300);
      height: .25rem;
    }

    .timeline:has(.timeline-middle hr):first-child {
      border-start-start-radius: 0;
      border-start-end-radius: var(--radius-selector);
      border-end-end-radius: var(--radius-selector);
      border-end-start-radius: 0;
    }

    .timeline:has(.timeline-middle hr):last-child, .timeline:not(:has(.timeline-middle)) :first-child hr:last-child {
      border-start-start-radius: var(--radius-selector);
      border-start-end-radius: 0;
      border-end-end-radius: 0;
      border-end-start-radius: var(--radius-selector);
    }

    .timeline:not(:has(.timeline-middle)) :last-child hr:first-child {
      border-start-start-radius: 0;
      border-start-end-radius: var(--radius-selector);
      border-end-end-radius: var(--radius-selector);
      border-end-start-radius: 0;
    }

    .checkbox {
      border: var(--border) solid var(--input-color, var(--color-base-content));
    }

    @supports (color: color-mix(in lab, red, red)) {
      .checkbox {
        border: var(--border) solid var(--input-color, color-mix(in oklab, var(--color-base-content) 20%, #0000));
      }
    }

    .checkbox {
      cursor: pointer;
      appearance: none;
      border-radius: var(--radius-selector);
      vertical-align: middle;
      color: var(--color-base-content);
      box-shadow: 0 1px oklch(0% 0 0 / calc(var(--depth) * .1)) inset, 0 0 #0000 inset, 0 0 #0000;
      --size: calc(var(--size-selector, .25rem) * 6);
      width: var(--size);
      height: var(--size);
      background-size: auto, calc(var(--noise) * 100%);
      background-image: none, var(--fx-noise);
      flex-shrink: 0;
      padding: .25rem;
      transition: background-color .2s, box-shadow .2s;
      display: inline-block;
      position: relative;
    }

    .checkbox:before {
      --tw-content: "";
      content: var(--tw-content);
      opacity: 0;
      clip-path: polygon(20% 100%, 20% 80%, 50% 80%, 50% 80%, 70% 80%, 70% 100%);
      width: 100%;
      height: 100%;
      box-shadow: 0px 3px 0 0px oklch(100% 0 0 / calc(var(--depth) * .1)) inset;
      background-color: currentColor;
      font-size: 1rem;
      line-height: .75;
      transition: clip-path .3s .1s, opacity .1s .1s, rotate .3s .1s, translate .3s .1s;
      display: block;
      rotate: 45deg;
    }

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

    .checkbox:checked, .checkbox[aria-checked="true"] {
      background-color: var(--input-color, #0000);
      box-shadow: 0 0 #0000 inset, 0 8px 0 -4px oklch(100% 0 0 / calc(var(--depth) * .1)) inset, 0 1px oklch(0% 0 0 / calc(var(--depth) * .1));
    }

    :is(.checkbox:checked, .checkbox[aria-checked="true"]):before {
      clip-path: polygon(20% 100%, 20% 80%, 50% 80%, 50% 0%, 70% 0%, 70% 100%);
      opacity: 1;
    }

    @media (forced-colors: active) {
      :is(.checkbox:checked, .checkbox[aria-checked="true"]):before {
        --tw-content: "✔︎";
        clip-path: none;
        background-color: #0000;
        rotate: 0deg;
      }
    }

    @media print {
      :is(.checkbox:checked, .checkbox[aria-checked="true"]):before {
        --tw-content: "✔︎";
        clip-path: none;
        background-color: #0000;
        rotate: 0deg;
      }
    }

    .checkbox:indeterminate {
      background-color: var(--input-color, var(--color-base-content));
    }

    @supports (color: color-mix(in lab, red, red)) {
      .checkbox:indeterminate {
        background-color: var(--input-color, color-mix(in oklab, var(--color-base-content) 20%, #0000));
      }
    }

    .checkbox:indeterminate:before {
      opacity: 1;
      clip-path: polygon(20% 100%, 20% 80%, 50% 80%, 50% 80%, 80% 80%, 80% 100%);
      translate: 0 -35%;
      rotate: 0deg;
    }

    .stats {
      border-radius: var(--radius-box);
      grid-auto-flow: column;
      display: inline-grid;
      position: relative;
      overflow-x: auto;
    }

    .label {
      white-space: nowrap;
      color: currentColor;
      align-items: center;
      gap: .375rem;
      display: inline-flex;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .label {
        color: color-mix(in oklab, currentcolor 60%, transparent);
      }
    }

    .label:has(input) {
      cursor: pointer;
    }

    .label:is(.input > *, .select > *) {
      white-space: nowrap;
      height: calc(100% - .5rem);
      font-size: inherit;
      align-items: center;
      padding-inline: .75rem;
      display: flex;
    }

    .label:is(.input > *, .select > *):first-child {
      border-inline-end: var(--border) solid currentColor;
      margin-inline: -.75rem .75rem;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .label:is(.input > *, .select > *):first-child {
        border-inline-end: var(--border) solid color-mix(in oklab, currentColor 10%, #0000);
      }
    }

    .label:is(.input > *, .select > *):last-child {
      border-inline-start: var(--border) solid currentColor;
      margin-inline: .75rem -.75rem;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .label:is(.input > *, .select > *):last-child {
        border-inline-start: var(--border) solid color-mix(in oklab, currentColor 10%, #0000);
      }
    }

    .status {
      aspect-ratio: 1;
      border-radius: var(--radius-selector);
      background-color: var(--color-base-content);
      width: .5rem;
      height: .5rem;
      display: inline-block;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .status {
        background-color: color-mix(in oklab, var(--color-base-content) 20%, transparent);
      }
    }

    .status {
      vertical-align: middle;
      color: #0000004d;
      background-position: center;
      background-repeat: no-repeat;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .status {
        color: color-mix(in oklab, var(--color-black) 30%, transparent);
      }
    }

    .status {
      background-image: radial-gradient(circle at 35% 30%, oklch(1 0 0 / calc(var(--depth) * .5)), #0000);
      box-shadow: 0 2px 3px -1px;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .status {
        box-shadow: 0 2px 3px -1px color-mix(in oklab, currentColor calc(var(--depth) * 100%), #0000);
      }
    }

    .link {
      cursor: pointer;
      text-decoration-line: underline;
    }

    .link:focus {
      --tw-outline-style: none;
      outline-style: none;
    }

    @media (forced-colors: active) {
      .link:focus {
        outline-offset: 2px;
        outline: 2px solid #0000;
      }
    }

    .link:focus-visible {
      outline-offset: 2px;
      outline: 2px solid;
    }
  }

  .prose :where(a.btn:not(.btn-link)):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    text-decoration-line: none;
  }

  @layer daisyui.l1.l2 {
    .btn:disabled:not(.btn-link, .btn-ghost) {
      background-color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn:disabled:not(.btn-link, .btn-ghost) {
        background-color: color-mix(in oklab, var(--color-base-content) 10%, transparent);
      }
    }

    .btn:disabled:not(.btn-link, .btn-ghost) {
      box-shadow: none;
    }

    .btn:disabled {
      pointer-events: none;
      --btn-border: #0000;
      --btn-noise: none;
      --btn-fg: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn:disabled {
        --btn-fg: color-mix(in oklch, var(--color-base-content) 20%, #0000);
      }
    }

    .btn[disabled]:not(.btn-link, .btn-ghost) {
      background-color: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn[disabled]:not(.btn-link, .btn-ghost) {
        background-color: color-mix(in oklab, var(--color-base-content) 10%, transparent);
      }
    }

    .btn[disabled]:not(.btn-link, .btn-ghost) {
      box-shadow: none;
    }

    .btn[disabled] {
      pointer-events: none;
      --btn-border: #0000;
      --btn-noise: none;
      --btn-fg: var(--color-base-content);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .btn[disabled] {
        --btn-fg: color-mix(in oklch, var(--color-base-content) 20%, #0000);
      }
    }

    .list .list-row:has(.list-col-grow:first-child) {
      --list-grid-cols: 1fr;
    }

    .list .list-row:has(.list-col-grow:nth-child(2)) {
      --list-grid-cols: minmax(0, auto) 1fr;
    }

    .list .list-row:has(.list-col-grow:nth-child(3)) {
      --list-grid-cols: minmax(0, auto) minmax(0, auto) 1fr;
    }

    .list .list-row:has(.list-col-grow:nth-child(4)) {
      --list-grid-cols: minmax(0, auto) minmax(0, auto) minmax(0, auto) 1fr;
    }

    .list .list-row:has(.list-col-grow:nth-child(5)) {
      --list-grid-cols: minmax(0, auto) minmax(0, auto) minmax(0, auto) minmax(0, auto) 1fr;
    }

    .list .list-row:has(.list-col-grow:nth-child(6)) {
      --list-grid-cols: minmax(0, auto) minmax(0, auto) minmax(0, auto) minmax(0, auto)
          minmax(0, auto) 1fr;
    }

    .list .list-row > * {
      grid-row-start: 1;
    }

    .checkbox:disabled {
      cursor: not-allowed;
      opacity: .2;
    }

    .loading-md {
      width: calc(var(--size-selector, .25rem) * 6);
    }

    .loading-dots {
      -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='4' cy='12' r='3'%3E%3Canimate attributeName='cy' values='12;6;12;12' keyTimes='0;0.286;0.571;1' dur='1.05s' repeatCount='indefinite' keySplines='.33,0,.66,.33;.33,.66,.66,1'/%3E%3C/circle%3E%3Ccircle cx='12' cy='12' r='3'%3E%3Canimate attributeName='cy' values='12;6;12;12' keyTimes='0;0.286;0.571;1' dur='1.05s' repeatCount='indefinite' keySplines='.33,0,.66,.33;.33,.66,.66,1' begin='0.1s'/%3E%3C/circle%3E%3Ccircle cx='20' cy='12' r='3'%3E%3Canimate attributeName='cy' values='12;6;12;12' keyTimes='0;0.286;0.571;1' dur='1.05s' repeatCount='indefinite' keySplines='.33,0,.66,.33;.33,.66,.66,1' begin='0.2s'/%3E%3C/circle%3E%3C/svg%3E");
      mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='4' cy='12' r='3'%3E%3Canimate attributeName='cy' values='12;6;12;12' keyTimes='0;0.286;0.571;1' dur='1.05s' repeatCount='indefinite' keySplines='.33,0,.66,.33;.33,.66,.66,1'/%3E%3C/circle%3E%3Ccircle cx='12' cy='12' r='3'%3E%3Canimate attributeName='cy' values='12;6;12;12' keyTimes='0;0.286;0.571;1' dur='1.05s' repeatCount='indefinite' keySplines='.33,0,.66,.33;.33,.66,.66,1' begin='0.1s'/%3E%3C/circle%3E%3Ccircle cx='20' cy='12' r='3'%3E%3Canimate attributeName='cy' values='12;6;12;12' keyTimes='0;0.286;0.571;1' dur='1.05s' repeatCount='indefinite' keySplines='.33,0,.66,.33;.33,.66,.66,1' begin='0.2s'/%3E%3C/circle%3E%3C/svg%3E");
    }

    .checkbox-sm {
      --size: calc(var(--size-selector, .25rem) * 5);
      padding: .1875rem;
    }

    .select-sm {
      --size: calc(var(--size-field, .25rem) * 8);
      font-size: .75rem;
    }

    .select-sm option {
      padding-block: .25rem;
      padding-inline: .625rem;
    }

    .btn-sm {
      --fontsize: .75rem;
      --btn-p: .75rem;
      --size: calc(var(--size-field, .25rem) * 8);
    }
  }

  .invisible {
    visibility: hidden;
  }

  .visible {
    visibility: visible;
  }

  .absolute {
    position: absolute;
  }

  .relative {
    position: relative;
  }

  .sticky {
    position: sticky;
  }

  .start {
    inset-inline-start: var(--spacing);
  }

  .top-0 {
    top: calc(var(--spacing) * 0);
  }

  .top-4 {
    top: calc(var(--spacing) * 4);
  }

  .top-6 {
    top: calc(var(--spacing) * 6);
  }

  .bottom-0 {
    bottom: calc(var(--spacing) * 0);
  }

  .left-2 {
    left: calc(var(--spacing) * 2);
  }

  .left-2\.5 {
    left: calc(var(--spacing) * 2.5);
  }

  .z-10 {
    z-index: 10;
  }

  .container {
    width: 100%;
  }

  @media (min-width: 40rem) {
    .container {
      max-width: 40rem;
    }
  }

  @media (min-width: 48rem) {
    .container {
      max-width: 48rem;
    }
  }

  @media (min-width: 64rem) {
    .container {
      max-width: 64rem;
    }
  }

  @media (min-width: 80rem) {
    .container {
      max-width: 80rem;
    }
  }

  @media (min-width: 96rem) {
    .container {
      max-width: 96rem;
    }
  }

  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }

  .mb-0\.5 {
    margin-bottom: calc(var(--spacing) * .5);
  }

  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }

  .ml-2 {
    margin-left: calc(var(--spacing) * 2);
  }

  .contents {
    display: contents;
  }

  .flex {
    display: flex;
  }

  .hidden {
    display: none;
  }

  .h-2 {
    height: calc(var(--spacing) * 2);
  }

  .h-3 {
    height: calc(var(--spacing) * 3);
  }

  .h-full {
    height: 100%;
  }

  .h-px {
    height: 1px;
  }

  .min-h-0 {
    min-height: calc(var(--spacing) * 0);
  }

  .w-0\.5 {
    width: calc(var(--spacing) * .5);
  }

  .w-2 {
    width: calc(var(--spacing) * 2);
  }

  .w-3 {
    width: calc(var(--spacing) * 3);
  }

  .w-fit {
    width: fit-content;
  }

  .min-w-0 {
    min-width: calc(var(--spacing) * 0);
  }

  .flex-1 {
    flex: 1;
  }

  .shrink-0 {
    flex-shrink: 0;
  }

  .cursor-pointer {
    cursor: pointer;
  }

  .flex-col {
    flex-direction: column;
  }

  .items-baseline {
    align-items: baseline;
  }

  .items-center {
    align-items: center;
  }

  .items-start {
    align-items: flex-start;
  }

  .justify-between {
    justify-content: space-between;
  }

  .justify-center {
    justify-content: center;
  }

  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }

  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }

  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }

  :where(.space-y-2 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
  }

  .overflow-auto {
    overflow: auto;
  }

  .rounded {
    border-radius: .25rem;
  }

  .rounded-full {
    border-radius: 3.40282e38px;
  }

  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }

  .border-base-200 {
    border-color: var(--color-base-200);
  }

  .border-primary-content {
    border-color: var(--color-primary-content);
  }

  .bg-base-100 {
    background-color: var(--color-base-100);
  }

  .bg-base-300, .bg-base-300\/50 {
    background-color: var(--color-base-300);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-base-300\/50 {
      background-color: color-mix(in oklab, var(--color-base-300) 50%, transparent);
    }
  }

  .bg-primary {
    background-color: var(--color-primary);
  }

  .p-2 {
    padding: calc(var(--spacing) * 2);
  }

  .p-3 {
    padding: calc(var(--spacing) * 3);
  }

  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }

  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }

  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }

  .py-1 {
    padding-block: calc(var(--spacing) * 1);
  }

  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }

  .py-10 {
    padding-block: calc(var(--spacing) * 10);
  }

  .pb-2 {
    padding-bottom: calc(var(--spacing) * 2);
  }

  .pb-4 {
    padding-bottom: calc(var(--spacing) * 4);
  }

  .pl-6 {
    padding-left: calc(var(--spacing) * 6);
  }

  .text-center {
    text-align: center;
  }

  .font-mono {
    font-family: var(--font-mono);
  }

  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }

  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }

  .text-\[10px\] {
    font-size: 10px;
  }

  .text-\[11px\] {
    font-size: 11px;
  }

  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }

  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }

  .tracking-wide {
    --tw-tracking: var(--tracking-wide);
    letter-spacing: var(--tracking-wide);
  }

  .text-base-content, .text-base-content\/40 {
    color: var(--color-base-content);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-base-content\/40 {
      color: color-mix(in oklab, var(--color-base-content) 40%, transparent);
    }
  }

  .text-base-content\/50 {
    color: var(--color-base-content);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-base-content\/50 {
      color: color-mix(in oklab, var(--color-base-content) 50%, transparent);
    }
  }

  .text-base-content\/60 {
    color: var(--color-base-content);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-base-content\/60 {
      color: color-mix(in oklab, var(--color-base-content) 60%, transparent);
    }
  }

  .text-success {
    color: var(--color-success);
  }

  .uppercase {
    text-transform: uppercase;
  }

  .opacity-30 {
    opacity: .3;
  }

  @layer daisyui.l1 {
    .btn-ghost:not(.btn-active, :hover, :active:focus, :focus-visible, input:checked:not(.filter .btn)) {
      --btn-shadow: "";
      --btn-bg: #0000;
      --btn-border: #0000;
      --btn-noise: none;
    }

    .btn-ghost:not(.btn-active, :hover, :active:focus, :focus-visible, input:checked:not(.filter .btn)):not(:disabled, [disabled], .btn-disabled) {
      --btn-fg: var(--btn-color, currentColor);
      outline-color: currentColor;
    }

    @media (hover: none) {
      .btn-ghost:not(.btn-active, :active, :focus-visible, input:checked:not(.filter .btn)):hover {
        --btn-shadow: "";
        --btn-bg: #0000;
        --btn-fg: var(--btn-color, currentColor);
        --btn-border: #0000;
        --btn-noise: none;
        outline-color: currentColor;
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-base-100:hover {
      background-color: var(--color-base-100);
    }

    .hover\:bg-base-200:hover {
      background-color: var(--color-base-200);
    }

    .hover\:text-base-content:hover {
      color: var(--color-base-content);
    }
  }
}

.last-timeline-item .timeline-line {
  display: none;
}

@keyframes rating {
  0%, 40% {
    filter: brightness(1.05) contrast(1.05);
    scale: 1.1;
  }
}

@keyframes dropdown {
  0% {
    opacity: 0;
  }
}

@keyframes radio {
  0% {
    padding: 5px;
  }

  50% {
    padding: 3px;
  }
}

@keyframes toast {
  0% {
    opacity: 0;
    scale: .9;
  }

  100% {
    opacity: 1;
    scale: 1;
  }
}

@keyframes rotator {
  89.9999%, 100% {
    --first-item-position: 0 0%;
  }

  90%, 99.9999% {
    --first-item-position: 0 calc(var(--items) * 100%);
  }

  100% {
    translate: 0 -100%;
  }
}

@keyframes skeleton {
  0% {
    background-position: 150%;
  }

  100% {
    background-position: -50%;
  }
}

@keyframes menu {
  0% {
    opacity: 0;
  }
}

@keyframes progress {
  50% {
    background-position-x: -115%;
  }
}

@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
}

@property --tw-tracking {
  syntax: "*";
  inherits: false
}

/* ---------- Tailwind 4 theme tokens (@layer theme) — from LFC ---------- */
/*   source: extracted/local-first-conf-patchwork-release/styles/06-root-3.css */
@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:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;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{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.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{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}: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)){::placeholder{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{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}:where(:root),:root:has(input.theme-controller[value=light]:checked),[data-theme=light]{color-scheme:light;--color-base-100:oklch(100% 0 0);--color-base-200:oklch(98% 0 0);--color-base-300:oklch(95% 0 0);--color-base-content:oklch(21% .006 285.885);--color-primary:oklch(45% .24 277.023);--color-primary-content:oklch(93% .034 272.788);--color-secondary:oklch(65% .241 354.308);--color-secondary-content:oklch(94% .028 342.258);--color-accent:oklch(77% .152 181.912);--color-accent-content:oklch(38% .063 188.416);--color-neutral:oklch(14% .005 285.823);--color-neutral-content:oklch(92% .004 286.32);--color-info:oklch(74% .16 232.661);--color-info-content:oklch(29% .066 243.157);--color-success:oklch(76% .177 163.223);--color-success-content:oklch(37% .077 168.94);--color-warning:oklch(82% .189 84.429);--color-warning-content:oklch(41% .112 45.904);--color-error:oklch(71% .194 13.428);--color-error-content:oklch(27% .105 12.094);--radius-selector:.5rem;--radius-field:.25rem;--radius-box:.5rem;--size-selector:.25rem;--size-field:.25rem;--border:1px;--depth:1;--noise:0}@media(prefers-color-scheme:dark){:root:not([data-theme]){color-scheme:dark;--color-base-100:oklch(25.33% .016 252.42);--color-base-200:oklch(23.26% .014 253.1);--color-base-300:oklch(21.15% .012 254.09);--color-base-content:oklch(97.807% .029 256.847);--color-primary:oklch(58% .233 277.117);--color-primary-content:oklch(96% .018 272.314);--color-secondary:oklch(65% .241 354.308);--color-secondary-content:oklch(94% .028 342.258);--color-accent:oklch(77% .152 181.912);--color-accent-content:oklch(38% .063 188.416);--color-neutral:oklch(14% .005 285.823);--color-neutral-content:oklch(92% .004 286.32);--color-info:oklch(74% .16 232.661);--color-info-content:oklch(29% .066 243.157);--color-success:oklch(76% .177 163.223);--color-success-content:oklch(37% .077 168.94);--color-warning:oklch(82% .189 84.429);--color-warning-content:oklch(41% .112 45.904);--color-error:oklch(71% .194 13.428);--color-error-content:oklch(27% .105 12.094);--radius-selector:.5rem;--radius-field:.25rem;--radius-box:.5rem;--size-selector:.25rem;--size-field:.25rem;--border:1px;--depth:1;--noise:0}}:root:has(input.theme-controller[value=light]:checked),[data-theme=light]{color-scheme:light;--color-base-100:oklch(100% 0 0);--color-base-200:oklch(98% 0 0);--color-base-300:oklch(95% 0 0);--color-base-content:oklch(21% .006 285.885);--color-primary:oklch(45% .24 277.023);--color-primary-content:oklch(93% .034 272.788);--color-secondary:oklch(65% .241 354.308);--color-secondary-content:oklch(94% .028 342.258);--color-accent:oklch(77% .152 181.912);--color-accent-content:oklch(38% .063 188.416);--color-neutral:oklch(14% .005 285.823);--color-neutral-content:oklch(92% .004 286.32);--color-info:oklch(74% .16 232.661);--color-info-content:oklch(29% .066 243.157);--color-success:oklch(76% .177 163.223);--color-success-content:oklch(37% .077 168.94);--color-warning:oklch(82% .189 84.429);--color-warning-content:oklch(41% .112 45.904);--color-error:oklch(71% .194 13.428);--color-error-content:oklch(27% .105 12.094);--radius-selector:.5rem;--radius-field:.25rem;--radius-box:.5rem;--size-selector:.25rem;--size-field:.25rem;--border:1px;--depth:1;--noise:0}:root:has(input.theme-controller[value=dark]:checked),[data-theme=dark]{color-scheme:dark;--color-base-100:oklch(25.33% .016 252.42);--color-base-200:oklch(23.26% .014 253.1);--color-base-300:oklch(21.15% .012 254.09);--color-base-content:oklch(97.807% .029 256.847);--color-primary:oklch(58% .233 277.117);--color-primary-content:oklch(96% .018 272.314);--color-secondary:oklch(65% .241 354.308);--color-secondary-content:oklch(94% .028 342.258);--color-accent:oklch(77% .152 181.912);--color-accent-content:oklch(38% .063 188.416);--color-neutral:oklch(14% .005 285.823);--color-neutral-content:oklch(92% .004 286.32);--color-info:oklch(74% .16 232.661);--color-info-content:oklch(29% .066 243.157);--color-success:oklch(76% .177 163.223);--color-success-content:oklch(37% .077 168.94);--color-warning:oklch(82% .189 84.429);--color-warning-content:oklch(41% .112 45.904);--color-error:oklch(71% .194 13.428);--color-error-content:oklch(27% .105 12.094);--radius-selector:.5rem;--radius-field:.25rem;--radius-box:.5rem;--size-selector:.25rem;--size-field:.25rem;--border:1px;--depth:1;--noise:0}:root{--fx-noise:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.34' numOctaves='4' stitchTiles='stitch'%3E%3C/feTurbulence%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23a)' opacity='0.2'%3E%3C/rect%3E%3C/svg%3E");scrollbar-color:currentColor #0000}@supports (color:color-mix(in lab,red,red)){:root{scrollbar-color:color-mix(in oklch,currentColor 35%,#0000) #0000}}@property --radialprogress{syntax:"<percentage>";inherits:true;initial-value:0%}:root:not(span){overflow:var(--page-overflow)}:root{background:var(--page-scroll-bg,var(--root-bg));--page-scroll-bg-on:linear-gradient(var(--root-bg,#0000), var(--root-bg,#0000)) var(--root-bg,#0000)}@supports (color:color-mix(in lab,red,red)){:root{--page-scroll-bg-on:linear-gradient(var(--root-bg,#0000), var(--root-bg,#0000)) color-mix(in srgb, var(--root-bg,#0000), oklch(0% 0 0) calc(var(--page-has-backdrop,0) * 40%))}}:root{--page-scroll-transition-on:background-color .3s ease-out;transition:var(--page-scroll-transition);scrollbar-gutter:var(--page-scroll-gutter,unset);scrollbar-gutter:if(style(--page-has-scroll: 1): var(--page-scroll-gutter,unset) ; else: unset)}@keyframes set-page-has-scroll{0%,to{--page-has-scroll:1}}:root,[data-theme]{background:var(--page-scroll-bg,var(--root-bg));color:var(--color-base-content)}:where(:root,[data-theme]){--root-bg:var(--color-base-100)}}@layer components;@layer utilities{@layer daisyui.l1.l2.l3{.tab{cursor:pointer;appearance:none;text-align:center;webkit-user-select:none;-webkit-user-select:none;user-select:none;flex-wrap:wrap;justify-content:center;align-items:center;display:inline-flex;position:relative}@media(hover:hover){.tab:hover{color:var(--color-base-content)}}.tab{--tab-p:.75rem;--tab-bg:var(--color-base-100);--tab-border-color:var(--color-base-300);--tab-radius-ss:0;--tab-radius-se:0;--tab-radius-es:0;--tab-radius-ee:0;--tab-order:0;--tab-radius-min:calc(.75rem - var(--border));--tab-radius-limit:min(var(--radius-field), var(--tab-radius-min));--tab-radius-grad:#0000 calc(69% - var(--border)), var(--tab-border-color) calc(69% - var(--border) + .25px), var(--tab-border-color) 69%, var(--tab-bg) calc(69% + .25px) ;order:var(--tab-order);height:var(--tab-height);padding-inline:var(--tab-p);border-color:#0000;font-size:.875rem}.tab:is(input[type=radio]){min-width:fit-content}.tab:is(input[type=radio]):after{--tw-content:attr(aria-label);content:var(--tw-content)}.tab:is(label){position:relative}.tab:is(label) input{cursor:pointer;appearance:none;opacity:0;position:absolute;inset:0}:is(.tab:checked,.tab:is(label:has(:checked)),.tab:is(.tab-active,[aria-selected=true],[aria-current=true],[aria-current=page]))+.tab-content{display:block}.tab:not(:checked,label:has(:checked),:hover,.tab-active,[aria-selected=true],[aria-current=true],[aria-current=page]){color:var(--color-base-content)}@supports (color:color-mix(in lab,red,red)){.tab:not(:checked,label:has(:checked),:hover,.tab-active,[aria-selected=true],[aria-current=true],[aria-current=page]){color:color-mix(in oklab,var(--color-base-content) 50%,transparent)}}.tab:not(input):empty{cursor:default;flex-grow:1}.tab:focus{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.tab:focus{outline-offset:2px;outline:2px solid #0000}}.tab:focus-visible,.tab:is(label:has(:checked:focus-visible)){outline-offset:-5px;outline:2px solid}.tab[disabled]{pointer-events:none;opacity:.4}.input{cursor:text;border:var(--border) solid #0000;appearance:none;background-color:var(--color-base-100);vertical-align:middle;white-space:nowrap;width:clamp(3rem,20rem,100%);height:var(--size);font-size:max(var(--font-size,.875rem),.875rem);touch-action:manipulation;border-color:var(--input-color);box-shadow:0 1px var(--input-color) inset,0 -1px oklch(100% 0 0 / calc(var(--depth) * .1)) inset;border-start-start-radius:var(--join-ss,var(--radius-field));border-start-end-radius:var(--join-se,var(--radius-field));border-end-end-radius:var(--join-ee,var(--radius-field));border-end-start-radius:var(--join-es,var(--radius-field));flex-shrink:1;align-items:center;gap:.5rem;padding-inline:.75rem;display:inline-flex;position:relative}@supports (color:color-mix(in lab,red,red)){.input{box-shadow:0 1px color-mix(in oklab,var(--input-color) calc(var(--depth) * 10%),#0000) inset,0 -1px oklch(100% 0 0 / calc(var(--depth) * .1)) inset}}.input{--size:calc(var(--size-field,.25rem) * 10);--input-color:var(--color-base-content)}@supports (color:color-mix(in lab,red,red)){.input{--input-color:color-mix(in oklab, var(--color-base-content) 20%, #0000)}}.input:where(input){display:inline-flex}.input :where(input){appearance:none;background-color:#0000;border:none;width:100%;height:100%;display:inline-flex}.input :where(input):focus,.input :where(input):focus-within{--tw-outline-style:none;outline-style:none}@media(forced-colors:active){.input :where(input):focus,.input :where(input):focus-within{outline-offset:2px;outline:2px solid #0000}}.input :where(input[type=url]),.input :where(input[type=email]){direction:ltr}.input :where(input[type=date]){display:inline-flex}.input:focus,.input:focus-within{--input-color:var(--color-base-content);box-shadow:0 1px var(--input-color)}@supports (color:color-mix(in lab,red,red)){.input:focus,.input:focus-within{box-shadow:0 1px color-mix(in oklab,var(--input-color) calc(var(--depth) * 10%),#0000)}}.input:focus,.input:focus-within{outline:2px solid var(--input-color);outline-offset:2px;isolation:isolate}@media(pointer:coarse){@supports (-webkit-touch-callout:none){.input:focus,.input:focus-within{--font-size:1rem}}}.input:has(>input[disabled]),.input:is(:disabled,[disabled]),fieldset:disabled .input{cursor:not-allowed;border-color:var(--color-base-200);background-color:var(--color-base-200);color:var(--color-base-content)}@supports (color:color-mix(in lab,red,red)){.input:has(>input[disabled]),.input:is(:disabled,[disabled]),fieldset:disabled .input{color:color-mix(in oklab,var(--color-base-content) 40%,transparent)}}:is(.input:has(>input[disabled]),.input:is(:disabled,[disabled]),fieldset:disabled .input)::placeholder{color:var(--color-base-content)}@supports (color:color-mix(in lab,red,red)){:is(.input:has(>input[disabled]),.input:is(:disabled,[disabled]),fieldset:disabled .input)::placeholder{color:color-mix(in oklab,var(--color-base-content) 20%,transparent)}}.input:has(>input[disabled]),.input:is(:disabled,[disabled]),fieldset:disabled .input{box-shadow:none}.input:has(>input[disabled])>input[disabled]{cursor:not-allowed}.input::-webkit-date-and-time-value{text-align:inherit}.input[type=number]::-webkit-inner-spin-button{margin-block:-.75rem;margin-inline-end:-.75rem}.input::-webkit-calendar-picker-indicator{position:absolute;inset-inline-end:.75em}.input:has(>input[type=date]) :where(input[type=date]){webkit-appearance:none;appearance:none;display:inline-flex}.input:has(>input[type=date]) input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;width:1em;height:1em;position:absolute;inset-inline-end:.75em}.tabs{--tabs-height:auto;--tabs-direction:row;--tab-height:calc(var(--size-field,.25rem) * 10);height:var(--tabs-height);flex-wrap:wrap;flex-direction:var(--tabs-direction);display:flex}}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.flex{display:flex}.h-full{height:100%}.min-h-0{min-height:calc(var(--spacing) * 0)}.w-full{width:100%}.flex-1{flex:1}.flex-col{flex-direction:column}.place-content-center{place-content:center}.place-items-start{place-items:start}.overflow-auto{overflow:auto}.bg-base-300{background-color:var(--color-base-300)}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}.context-sidebar .sidebar-close-button{cursor:pointer;opacity:.5;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;margin-top:16px;margin-right:4px;padding-inline:.5rem;display:flex}.context-sidebar .sidebar-close-button:hover{opacity:1}@keyframes rating{0%,40%{filter:brightness(1.05)contrast(1.05);scale:1.1}}@keyframes dropdown{0%{opacity:0}}@keyframes radio{0%{padding:5px}50%{padding:3px}}@keyframes toast{0%{opacity:0;scale:.9}to{opacity:1;scale:1}}@keyframes rotator{89.9999%,to{--first-item-position:0 0%}90%,99.9999%{--first-item-position:0 calc(var(--items) * 100%)}to{translate:0 -100%}}@keyframes skeleton{0%{background-position:150%}to{background-position:-50%}}@keyframes menu{0%{opacity:0}}@keyframes progress{50%{background-position-x:-115%}}

/* ---------- daisyUI base color tokens — from LFC ---------- */
/*   source: extracted/local-first-conf-patchwork-release/styles/03-root.css */
:root {
  --color-base-100: #ffffff;
  --color-base-200: #f2f2f2;
  --color-base-300: #e5e6e6;
  --color-base-content: #1f2937;
}

/* Layout */

.frame {
  display: flex;
  width: 100%;
  height: 100%;
}

.sidebar {
  position: relative;
  display: flex;
  flex: none;
  overflow: hidden;
}

.sidebar[data-collapsed] {
  overflow: visible;
}

.sidebar[data-side="left"] {
  background: var(--color-base-100);
}

.sidebar[data-side="right"] {
  background: var(--color-base-100);
}

.main-area {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

.toolbar {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
  background: var(--color-base-200);
  border-bottom: 1px solid var(--color-base-300);
}

.toolbar patchwork-view {
  display: flex;
  width: fit-content;
  height: 2rem;
  overflow: hidden;
}

.document-view {
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.document-view patchwork-view {
  display: block;
  width: 100%;
  height: 100%;
}

.placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--color-base-content);
}

.sidebar patchwork-view {
  display: block;
  width: 100%;
  height: 100%;
}

/* Debug Registry Toast */
.debug-registry-toast {
  position: fixed;
  bottom: 1rem;
  right: 1rem;
  z-index: 9999;
  max-width: 360px;
  font-family: "JetBrains Mono", "SF Mono", "Monaco", monospace;
  font-size: 0.75rem;
  background: oklch(0.15 0.01 270);
  border: 1px solid oklch(0.35 0.03 270);
  border-radius: 8px;
  box-shadow:
    0 8px 32px oklch(0 0 0 / 0.4),
    0 0 0 1px oklch(1 0 0 / 0.05) inset;
  overflow: hidden;
  backdrop-filter: blur(12px);
}

.debug-registry-toast__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 0.75rem;
  background: oklch(0.2 0.02 270);
  border-bottom: 1px solid oklch(0.3 0.02 270);
}

.debug-registry-toast__title {
  color: oklch(0.85 0.1 270);
  font-weight: 600;
  letter-spacing: 0.02em;
}

.debug-registry-toast__clear {
  background: none;
  border: none;
  color: oklch(0.6 0.05 270);
  cursor: pointer;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  transition: all 0.15s ease;
}

.debug-registry-toast__clear:hover {
  background: oklch(0.25 0.02 270);
  color: oklch(0.9 0.05 0);
}

.debug-registry-toast__list {
  max-height: 300px;
  overflow-y: auto;
}

.debug-registry-toast__item {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  border-left: 3px solid transparent;
  cursor: pointer;
  transition: all 0.15s ease;
  animation: toast-slide-in 0.2s ease-out;
}

@keyframes toast-slide-in {
  from {
    opacity: 0;
    transform: translateX(20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.debug-registry-toast__item:hover {
  background: oklch(0.2 0.01 270);
}

.debug-registry-toast__item:not(:last-child) {
  border-bottom: 1px solid oklch(0.25 0.01 270);
}

.debug-registry-toast__icon {
  font-size: 0.875rem;
  line-height: 1;
  flex-shrink: 0;
}

.debug-registry-toast__content {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  min-width: 0;
}

.debug-registry-toast__event-type {
  color: oklch(0.7 0.15 150);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 0.625rem;
}

.debug-registry-toast__plugin-type {
  color: oklch(0.6 0.1 60);
  font-size: 0.6875rem;
}

.debug-registry-toast__plugin-id {
  color: oklch(0.9 0.02 270);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Custom colors for event types */
:root {
  --debug-toast-registered: oklch(0.65 0.2 250);
  --debug-toast-loaded: oklch(0.7 0.2 150);
  --debug-toast-removed: oklch(0.65 0.25 25);
  --debug-toast-changed: oklch(0.75 0.2 80);
}

.sidebar-toggle {
  height: 100%;
  padding: 0;
  margin: 0;
  border: 0;
  background: transparent;
  width: 2px;
  z-index: 1;
  cursor: pointer;
  &::before {
    content: "";
    display: block;
    width: 20px;
    height: 100%;
    margin-left: -10px;
  }
  &:hover {
    background: var(--color-base-content);
  }
}

.sidebar-toggle--resizable {
  cursor: col-resize;
  &:hover {
    cursor: col-resize;
  }
  &:active {
    cursor: col-resize;
  }
}

/* Sidebar resize handles */
.sidebar-resize-handle {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 6px;
  cursor: col-resize;
  z-index: 10;
  background: transparent;
  transition: background-color 0.15s ease;
}

.sidebar-resize-handle:hover,
.sidebar-resize-handle:active {
  background-color: oklch(0.6 0.15 250 / 0.5);
}

.sidebar-resize-handle::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 2px;
  height: 32px;
  background-color: oklch(0.5 0.05 270);
  border-radius: 1px;
  opacity: 0;
  transition: opacity 0.15s ease;
}

.sidebar-resize-handle:hover::after {
  opacity: 1;
}

.sidebar-resize-handle--right {
  right: 0;
}

.sidebar-resize-handle--left {
  left: 0;
}

/* ---------- Sideboard component CSS — from WP archive ---------- */
/*   source: extracted/weekly-planning/automerge:kFcrzeDmr5zXE1jShvxUPsoToAN#2vp1K6wXSyE9pNpLY3GeerNxyaCLoFV7rirXvaatMfoKCNGYHb/dist/index.css */
/* src/index.css */
:root {
  --sideboard-fill: oklch(0.86 0.16 87.44 / 1);
  --sideboard-fill-offset: color-mix( in oklab, var(--sideboard-fill), oklch(1 0 0 / 1) 10% );
  --sideboard-line: black;
  --sideboard-widget-fill: white;
  --sideboard-widget-line: var(--sideboard-line);
  --sideboard-padding-x: 0.5rem;
  --sideboard-radius: 0.275rem;
  --placeholder-line: #808e80;
  --sideboard-search-line: #000;
  --sideboard-fill: oklch(from #99eeff l c h);
  --sideboard-primary: oklch(from #d9f4ff l c h);
  --sideboard-create-new-fill: white;
  --sideboard-create-new-line: color-mix( in oklch, var(--sideboard-primary), black 30% );
  --sideboard-create-new-border-line: color-mix( in oklch, var(--sideboard-primary), var(--sideboard-create-new-fill) 50% );
  --sideboard-create-new-shadow-color: color-mix( in oklch, var(--sideboard-fill), var(--sideboard-line) 10% );
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --sideboard-fill: black;
    --sideboard-line: white;
    --sideboard-widget-fill: var(--sideboard-fill-offset);
    --sideboard-create-new-fill: #333;
    --sideboard-create-new-line: #ccc;
    --sideboard-create-new-shadow-color: #111;
    --sideboard-create-new-border-line: #555;
    --sideboard-primary: #0099cc;
  }
}
.sideboard {
  background: var(--sideboard-fill);
  display: flex;
  height: 100%;
  flex-direction: column;
  gap: 0.75rem;
  font-family: system-ui, sans-serif;
  padding-inline: var(--sideboard-padding-x);
  padding-bottom: env(safe-area-inset-bottom);
  --depth: 0;
  .sideboard-close-button {
    display: flex;
    align-items: center;
    align-self: flex-start;
    padding: 0.25rem;
    margin-top: 12px;
    margin-left: -2px;
    background: transparent;
    border: none;
    cursor: pointer;
    opacity: 0.5;
    color: var(--sideboard-line);
  }
  .sideboard-close-button:hover {
    opacity: 1;
  }
}
.sideboard-header {
  flex-shrink: 0;
  container-type: inline-size;
  height: 4rem;
  display: flex;
  overflow: hidden;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  .create-new-button {
    display: flex;
    padding-inline: 0.75rem;
    padding-block: 0.25rem;
    border: 2px solid var(--sideboard-create-new-border-line);
    border-radius: var(--sideboard-radius);
    background: var(--sideboard-create-new-fill);
    color: var(--sideboard-line);
    font-weight: 400;
    width: 100%;
    align-items: center;
    justify-content: start;
    white-space: nowrap;
    font-size: 0.9rem;
    text-align: left;
    gap: 1ex;
    position: relative;
    flex-shrink: 0;
  }
}
.icon {
  height: 1em;
}
.sideboard__filter-container {
  position: relative;
  font-size: 0.875rem;
  border-radius: var(--sideboard-radius);
  .search-icon {
    height: 1em;
    top: 0.4lh;
    left: 2px;
    position: absolute;
    z-index: 1;
    stroke: var(--placeholder-line);
  }
  &:focus-within {
    .search-icon {
      stroke: #000;
    }
  }
}
.sideboard__filter {
  width: 100%;
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
  padding-left: 2em;
  padding-right: 0.75rem;
  padding-top: 0.375rem;
  padding-bottom: 0.375rem;
  border: none;
  box-shadow: 0 1px 2px rgba(0, 20, 50, 0.05);
  border-radius: var(--sideboard-radius);
  &::placeholder {
    color: var(--placeholder-line);
  }
  &:focus-visible {
    outline-color: var(--sidebar-widget-line);
    outline-offset: 1px;
    box-shadow: 0 0 0 4px #fff;
    border-radius: var(--sideboard-radius);
  }
}
.sideboard__doclist {
  --doclist-padding-x: 0.75rem;
  display: flex;
  flex-direction: column;
  border-radius: var(--sideboard-radius);
  box-shadow: 0 1px 2px rgba(0, 20, 50, 0.05);
  width: 100%;
  max-height: 100%;
  overflow: scroll;
  transition: background-color 0.2s ease, box-shadow 0.2s ease;
  &::-webkit-scrollbar {
    display: none;
  }
}
.sideboard__doclist--drag-over {
  background: color-mix(in oklch, var(--sideboard-primary), transparent 95%);
  box-shadow: 0 0 0 2px var(--sideboard-primary) inset, 0 1px 2px rgba(0, 20, 50, 0.05);
}
.document-list-item {
  display: flex;
  gap: 0.25ch;
  padding-inline: var(--doclist-padding-x);
  padding-block: 0.5rem;
  font-weight: 400;
  color: var(--sidebar-widget-line);
  cursor: default;
  position: relative;
  .create-new-button {
    margin-left: auto;
  }
  .create-new-button__text {
    display: none;
  }
  &:focus-visible {
    outline-color: #000;
    outline-offset: -2px;
    box-shadow: 0 0 0 4px #fff;
    border-radius: var(--sideboard-radius);
  }
  &:active {
    outline: 0;
    box-shadow: 0;
  }
  &[aria-selected=true] {
    background: var(--sideboard-primary);
    .sideboard__doclist > &:first-child {
      border-top-left-radius: var(--sideboard-radius);
      border-top-right-radius: var(--sideboard-radius);
    }
    .sideboard__doclist > &:last-child {
      border-bottom-left-radius: var(--sideboard-radius);
      border-bottom-right-radius: var(--sideboard-radius);
    }
  }
  &[aria-checked=true] {
    outline: 2px dashed color-mix(in oklch, var(--sideboard-line), transparent 50%);
    outline-offset: -4px;
  }
  &[data-dnd-droplist-state]::before {
    content: "";
    position: absolute;
    left: 0;
    margin-left: calc(var(--depth) * 1.75rem);
    right: 0;
    height: 2px;
    background: var(--sideboard-line);
  }
  &[data-dnd-droplist-state=above]::before {
    top: -1px;
  }
  &[data-dnd-droplist-state=below]::before {
    bottom: -1px;
  }
}
.document-list-folder[data-drop-state=inside] {
  outline: 2px solid var(--sideboard-primary);
  outline-offset: -2px;
  border-radius: var(--sideboard-radius);
  background: color-mix(in oklch, var(--sideboard-primary), transparent 50%);
  > .document-list-item::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--sideboard-line);
    bottom: 0;
  }
  [data-dnd-droplist-state]::before {
    display: none;
  }
}
.document-list-item__name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: block;
  flex: 1;
  min-width: 0;
  &:is(input) {
    padding: 4px;
    margin: -4px;
  }
}
.document-list-item__unprotected {
  margin-left: auto;
  font-size: 0.75rem;
  color: var(--placeholder-line);
  white-space: nowrap;
}
.document-list-folder__toggle {
  margin-left: -0.75ch;
  padding-inline: 0.25ch;
  &:hover {
    background: #00000011;
  }
}
.document-list-folder__contents--hidden {
  display: none;
}
.document-list-folder__circular-ref {
  padding: 0.5rem;
  padding-left: calc(2.2rem * var(--depth));
  color: #666;
  font-style: italic;
  font-size: 0.9em;
}
.sideboard__item--invisible {
  display: none;
}
.sideboard__item--visible,
.sideboard__item--invisible:has(.sideboard__item--visible) {
  display: block;
}
.document-list-folder__contents .document-list-item {
  padding-left: calc(1.8rem * var(--depth));
}
.sideboard-footer {
  container-type: inline-size;
  height: 4rem;
  min-height: 4em;
  display: flex;
  overflow: hidden;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: var(--sideboard-padding-x);
  padding-bottom: calc(0.25rem + env(safe-area-inset-bottom));
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
  background: var(--sideboard-footer-fill);
  color: var(--sideboard-line);
  border-top: 1px solid color-mix(in oklab, color-mix(in oklab, var(--sideboard-fill), oklch(1 0 0 / 1) 10%), oklch(0 0 0 / 1) 4%);
  margin-top: auto;
  box-shadow: 0 -1px 1px color-mix(in oklab, color-mix(in oklab, var(--sideboard-fill), oklch(1 0 0 / 1) 10%), oklch(0 0 0 / 1) 4%);
  > button {
    border: 1px solid transparent;
    padding-inline: 0.25rem;
    padding-block: 0.125rem;
    border-radius: 3px;
    white-space: nowrap;
    &:hover {
      border: 1px solid color-mix(in oklab, color-mix(in oklab, var(--sideboard-fill), oklch(1 0 0 / 1) 10%), oklch(0 0 0 / 1) 4%);
    }
  }
}
.sideboard-widget {
  margin-top: 0.5rem;
  width: 100%;
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
}
.sideboard-widget:empty {
  display: none;
}
.sideboard__filter-container:has(~ .sideboard__doclist:empty) {
  display: none;
}
.popmenu__trigger,
.popmenu__sub-trigger {
  cursor: default;
  user-select: none;
  width: 100%;
  text-align: left;
}
.popmenu__sub-content,
.popmenu__content {
  z-index: 2;
  min-width: 220px;
  max-height: min(400px, 50vh);
  overflow-y: auto;
  padding: 4px;
  background-color: var(--sideboard-widget-fill);
  font-size: 0.8rem;
  border-radius: 6px;
  border: 1px solid hsl(240 6% 90%);
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  outline: none;
  transform-origin: var(--kb-menu-content-transform-origin);
  animation: contentHide 250ms ease-in forwards;
}
.popmenu__content[data-expanded],
.popmenu__sub-content[data-expanded] {
  animation: contentShow 250ms ease-out;
}
.popmenu__item,
.popmenu__checkbox-item,
.popmenu__radio-item,
.popmenu__sub-trigger {
  font-size: 0.8rem;
  line-height: 1;
  color: var(--sideboard-widget-line);
  border-radius: 4px;
  display: flex;
  align-items: center;
  height: 32px;
  padding-inline: 12px;
  padding-block: 6px;
  position: relative;
  user-select: none;
  outline: none;
  cursor: default;
}
.popmenu__sub-trigger[data-expanded] {
  background-color: var(--sideboard-fill-offset);
  color: var(--sideboard-line);
}
.popmenu__item[data-disabled],
.popmenu__checkbox-item[data-disabled],
.popmenu__radio-item[data-disabled],
.popmenu__sub-trigger[data-disabled] {
  color: hsl(240 5% 65%);
  opacity: 0.5;
  pointer-events: none;
}
.popmenu__item[data-highlighted],
.popmenu__checkbox-item[data-highlighted],
.popmenu__radio-item[data-highlighted],
.popmenu__sub-trigger[data-highlighted] {
  outline: none;
  background-color: color-mix(in oklch, var(--sideboard-primary), var(--sideboard-widget-fill) 20%);
  color: var(--sideboard-widget-line);
}
@keyframes contentShow {
  from {
    opacity: 0;
    transform: scale(0.96);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes contentHide {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0.96);
  }
}
.popmenu__item--highlighted {
  outline: none;
  background-color: color-mix(in oklch, var(--sideboard-primary), var(--sideboard-widget-fill) 20%);
  color: var(--sideboard-widget-line);
}
.create-new-filter {
  padding: 4px;
}
.create-new-filter__input {
  width: 100%;
  box-sizing: border-box;
  padding: 6px 8px;
  font-size: 0.8rem;
  border: 1px solid hsl(240 6% 80%);
  border-radius: 4px;
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
  outline: none;
}
.create-new-filter__input:focus {
  border-color: var(--sideboard-primary);
}
.create-new-filter__input::placeholder {
  color: hsl(240 5% 65%);
}
.share-modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 2rem;
}
.share-modal__content {
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
  border-radius: 8px;
  width: 90vw;
  max-width: 480px;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.15);
  overflow: hidden;
}
.share-modal__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid color-mix(in oklab, var(--sideboard-widget-fill), black 15%);
}
.share-modal__header h2 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 600;
}
.share-modal__close {
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 1.5rem;
  color: var(--sideboard-widget-line);
  width: 2rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: all 0.15s ease;
}
.share-modal__close:hover {
  background: color-mix(in oklab, var(--sideboard-widget-fill), black 10%);
}
.share-modal__body {
  padding: 1.5rem;
  overflow-y: auto;
  flex: 1;
}
.share-modal__public-section {
  margin-bottom: 1rem;
}
.share-modal__public-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.share-modal__public-status {
  font-size: 0.875rem;
  color: var(--sideboard-widget-line);
}
.share-modal__public-actions {
  display: flex;
  gap: 0.5rem;
}
.share-modal__form {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}
.share-modal__form-actions {
  display: flex;
  gap: 0.5rem;
}
.share-modal__input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid color-mix(in oklab, var(--sideboard-widget-fill), black 15%);
  border-radius: 4px;
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
  font-size: 0.875rem;
  font-family:
    "SF Mono",
    "Monaco",
    "Menlo",
    "Consolas",
    monospace;
  resize: vertical;
  min-height: 4rem;
}
.share-modal__input:focus {
  outline: 2px solid var(--sideboard-primary);
  outline-offset: 1px;
}
.share-modal__select {
  padding: 0.5rem 0.75rem;
  border: 1px solid color-mix(in oklab, var(--sideboard-widget-fill), black 15%);
  border-radius: 4px;
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
  font-size: 0.875rem;
}
.share-modal__add-button {
  padding: 0.5rem 1rem;
  border-radius: 4px;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  background: color-mix(in oklch, #3b82f6, white 10%);
  border: 1px solid color-mix(in oklch, #3b82f6, black 5%);
  color: white;
  transition: all 0.15s ease;
}
.share-modal__add-button:hover:not(:disabled) {
  background: #3b82f6;
}
.share-modal__add-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.share-modal__divider {
  border: none;
  border-top: 1px solid color-mix(in oklab, var(--sideboard-widget-fill), black 15%);
  margin: 0 0 1.5rem 0;
}
.share-modal__section-title {
  font-size: 0.875rem;
  font-weight: 600;
  margin: 0 0 1rem 0;
}
.share-modal__loading,
.share-modal__empty {
  font-size: 0.875rem;
  color: color-mix(in oklab, var(--sideboard-widget-line), transparent 40%);
  font-style: italic;
}
.share-modal__error {
  padding: 0.5rem 0.75rem;
  background: color-mix(in oklch, #ef4444, white 80%);
  border: 1px solid color-mix(in oklch, #ef4444, white 60%);
  border-radius: 4px;
  color: #991b1b;
  font-size: 0.875rem;
  margin-bottom: 1rem;
}
.share-modal__member-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.share-modal__member {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem;
  background: color-mix(in oklab, var(--sideboard-widget-fill), black 5%);
  border-radius: 4px;
}
.share-modal__member-info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.share-modal__member-id {
  font-family:
    "SF Mono",
    "Monaco",
    "Menlo",
    "Consolas",
    monospace;
  font-size: 0.8rem;
}
.share-modal__member-id--you {
  font-weight: 600;
}
.share-modal__member-id--public {
  font-weight: 600;
  color: #22c55e;
}
.share-modal__you-label {
  color: var(--sideboard-primary);
  font-weight: 600;
}
.share-modal__member-access {
  font-size: 0.75rem;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--sideboard-widget-line), transparent 30%);
}
.share-modal__remove-button {
  background: transparent;
  border: none;
  cursor: pointer;
  color: color-mix(in oklab, var(--sideboard-widget-line), transparent 40%);
  padding: 0.25rem;
  border-radius: 4px;
  transition: all 0.15s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.share-modal__remove-button:hover {
  color: #ef4444;
  background: color-mix(in oklch, #ef4444, transparent 90%);
}
@media (prefers-color-scheme: dark) {
  .share-modal__header {
    border-bottom-color: color-mix(in oklab, var(--sideboard-widget-fill), white 15%);
  }
  .share-modal__close:hover {
    background: color-mix(in oklab, var(--sideboard-widget-fill), white 10%);
  }
  .share-modal__input,
  .share-modal__select {
    border-color: color-mix(in oklab, var(--sideboard-widget-fill), white 15%);
  }
  .share-modal__divider {
    border-top-color: color-mix(in oklab, var(--sideboard-widget-fill), white 15%);
  }
  .share-modal__member {
    background: color-mix(in oklab, var(--sideboard-widget-fill), white 8%);
  }
  .share-modal__error {
    background: color-mix(in oklch, #ef4444, black 70%);
    border-color: color-mix(in oklch, #ef4444, black 50%);
    color: #fca5a5;
  }
}
.debug-toggle__label {
  font-size: 0.875rem;
  font-weight: 500;
  user-select: none;
}
/*# sourceMappingURL=index.css.map */


/* ---------- Sideboard fill colors (--sideboard-fill, etc.) — from LFC ---------- */
/*   source: extracted/local-first-conf-patchwork-release/styles/16-root-5.css */
/* src/index.css */
:root {
  --sideboard-fill: oklch(0.86 0.16 87.44 / 1);
  --sideboard-fill-offset: color-mix( in oklab, var(--sideboard-fill), oklch(1 0 0 / 1) 10% );
  --sideboard-line: black;
  --sideboard-widget-fill: white;
  --sideboard-widget-line: var(--sideboard-line);
  --sideboard-padding-x: 0.5rem;
  --sideboard-radius: 0.275rem;
  --placeholder-line: #808e80;
  --sideboard-search-line: #000;
  --sideboard-fill: oklch(from #99eeff l c h);
  --sideboard-primary: oklch(from #d9f4ff l c h);
  --sideboard-create-new-fill: white;
  --sideboard-create-new-line: color-mix( in oklch, var(--sideboard-primary), black 30% );
  --sideboard-create-new-border-line: color-mix( in oklch, var(--sideboard-primary), var(--sideboard-create-new-fill) 50% );
  --sideboard-create-new-shadow-color: color-mix( in oklch, var(--sideboard-fill), var(--sideboard-line) 10% );
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --sideboard-fill: black;
    --sideboard-line: white;
    --sideboard-widget-fill: var(--sideboard-fill-offset);
    --sideboard-create-new-fill: #333;
    --sideboard-create-new-line: #ccc;
    --sideboard-create-new-shadow-color: #111;
    --sideboard-create-new-border-line: #555;
    --sideboard-primary: #0099cc;
  }
}
.sideboard {
  background: var(--sideboard-fill);
  display: flex;
  height: 100%;
  flex-direction: column;
  gap: 0.75rem;
  font-family: system-ui, sans-serif;
  padding-inline: var(--sideboard-padding-x);
  padding-bottom: env(safe-area-inset-bottom);
  --depth: 0;
  .sideboard-close-button {
    display: flex;
    align-items: center;
    align-self: flex-start;
    padding: 0.25rem;
    margin-top: 12px;
    margin-left: -2px;
    background: transparent;
    border: none;
    cursor: pointer;
    opacity: 0.5;
    color: var(--sideboard-line);
  }
  .sideboard-close-button:hover {
    opacity: 1;
  }
}
.sideboard-header {
  flex-shrink: 0;
  container-type: inline-size;
  height: 4rem;
  display: flex;
  overflow: hidden;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  .create-new-button {
    display: flex;
    padding-inline: 0.75rem;
    padding-block: 0.25rem;
    border: 2px solid var(--sideboard-create-new-border-line);
    border-radius: var(--sideboard-radius);
    background: var(--sideboard-create-new-fill);
    color: var(--sideboard-line);
    font-weight: 400;
    width: 100%;
    align-items: center;
    justify-content: start;
    white-space: nowrap;
    font-size: 0.9rem;
    text-align: left;
    gap: 1ex;
    position: relative;
    flex-shrink: 0;
  }
}
.icon {
  height: 1em;
}
.sideboard__filter-container {
  position: relative;
  font-size: 0.875rem;
  border-radius: var(--sideboard-radius);
  .search-icon {
    height: 1em;
    top: 0.4lh;
    left: 2px;
    position: absolute;
    z-index: 1;
    stroke: var(--placeholder-line);
  }
  &:focus-within {
    .search-icon {
      stroke: #000;
    }
  }
}
.sideboard__filter {
  width: 100%;
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
  padding-left: 2em;
  padding-right: 0.75rem;
  padding-top: 0.375rem;
  padding-bottom: 0.375rem;
  border: none;
  box-shadow: 0 1px 2px rgba(0, 20, 50, 0.05);
  border-radius: var(--sideboard-radius);
  &::placeholder {
    color: var(--placeholder-line);
  }
  &:focus-visible {
    outline-color: var(--sidebar-widget-line);
    outline-offset: 1px;
    box-shadow: 0 0 0 4px #fff;
    border-radius: var(--sideboard-radius);
  }
}
.sideboard__doclist {
  --doclist-padding-x: 0.75rem;
  display: flex;
  flex-direction: column;
  border-radius: var(--sideboard-radius);
  box-shadow: 0 1px 2px rgba(0, 20, 50, 0.05);
  width: 100%;
  max-height: 100%;
  overflow: scroll;
  transition: background-color 0.2s ease, box-shadow 0.2s ease;
  &::-webkit-scrollbar {
    display: none;
  }
}
.sideboard__doclist--drag-over {
  background: color-mix(in oklch, var(--sideboard-primary), transparent 95%);
  box-shadow: 0 0 0 2px var(--sideboard-primary) inset, 0 1px 2px rgba(0, 20, 50, 0.05);
}
.document-list-item {
  display: flex;
  gap: 0.25ch;
  padding-inline: var(--doclist-padding-x);
  padding-block: 0.5rem;
  font-weight: 400;
  color: var(--sidebar-widget-line);
  cursor: default;
  position: relative;
  .create-new-button {
    margin-left: auto;
  }
  .create-new-button__text {
    display: none;
  }
  &:focus-visible {
    outline-color: #000;
    outline-offset: -2px;
    box-shadow: 0 0 0 4px #fff;
    border-radius: var(--sideboard-radius);
  }
  &:active {
    outline: 0;
    box-shadow: 0;
  }
  &[aria-selected=true] {
    background: var(--sideboard-primary);
    .sideboard__doclist > &:first-child {
      border-top-left-radius: var(--sideboard-radius);
      border-top-right-radius: var(--sideboard-radius);
    }
    .sideboard__doclist > &:last-child {
      border-bottom-left-radius: var(--sideboard-radius);
      border-bottom-right-radius: var(--sideboard-radius);
    }
  }
  &[aria-checked=true] {
    outline: 2px dashed color-mix(in oklch, var(--sideboard-line), transparent 50%);
    outline-offset: -4px;
  }
  &[data-dnd-dragging] {
    opacity: 0.4;
  }
  &[data-dnd-droplist-state]::before {
    content: "";
    position: absolute;
    left: 0;
    margin-left: calc(var(--depth) * 1.75rem);
    right: 0;
    height: 2px;
    background: var(--sideboard-line);
  }
  &[data-dnd-droplist-state=above]::before {
    top: -1px;
  }
  &[data-dnd-droplist-state=below]::before {
    bottom: -1px;
  }
}
.document-list-folder[data-drop-state=inside] {
  outline: 2px solid var(--sideboard-primary);
  outline-offset: -2px;
  border-radius: var(--sideboard-radius);
  background: color-mix(in oklch, var(--sideboard-primary), transparent 50%);
  > .document-list-item::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--sideboard-line);
    bottom: 0;
  }
  [data-dnd-droplist-state]::before {
    display: none;
  }
}
.document-list-item__name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: block;
  flex: 1;
  min-width: 0;
  &:is(input) {
    padding: 4px;
    margin: -4px;
  }
}
.document-list-item__unprotected {
  margin-left: auto;
  font-size: 0.75rem;
  color: var(--placeholder-line);
  white-space: nowrap;
}
.document-list-folder__toggle {
  margin-left: -0.75ch;
  padding-inline: 0.25ch;
  &:hover {
    background: #00000011;
  }
}
.document-list-folder__contents--hidden {
  display: none;
}
.document-list-folder__circular-ref {
  padding: 0.5rem;
  padding-left: calc(2.2rem * var(--depth));
  color: #666;
  font-style: italic;
  font-size: 0.9em;
}
.sideboard__item {
  content-visibility: auto;
  contain-intrinsic-size: auto 2.25rem;
}
.sideboard__item--invisible {
  display: none;
}
.sideboard__item--visible,
.sideboard__item--invisible:has(.sideboard__item--visible) {
  display: block;
}
.document-list-folder__contents .document-list-item {
  padding-left: calc(1.8rem * var(--depth));
}
.sideboard-footer {
  container-type: inline-size;
  height: 4rem;
  min-height: 4em;
  display: flex;
  overflow: hidden;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: var(--sideboard-padding-x);
  padding-bottom: calc(0.25rem + env(safe-area-inset-bottom));
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
  background: var(--sideboard-footer-fill);
  color: var(--sideboard-line);
  border-top: 1px solid color-mix(in oklab, color-mix(in oklab, var(--sideboard-fill), oklch(1 0 0 / 1) 10%), oklch(0 0 0 / 1) 4%);
  margin-top: auto;
  box-shadow: 0 -1px 1px color-mix(in oklab, color-mix(in oklab, var(--sideboard-fill), oklch(1 0 0 / 1) 10%), oklch(0 0 0 / 1) 4%);
  > button {
    border: 1px solid transparent;
    padding-inline: 0.25rem;
    padding-block: 0.125rem;
    border-radius: 3px;
    white-space: nowrap;
    &:hover {
      border: 1px solid color-mix(in oklab, color-mix(in oklab, var(--sideboard-fill), oklch(1 0 0 / 1) 10%), oklch(0 0 0 / 1) 4%);
    }
  }
}
.sideboard-widget {
  margin-top: 0.5rem;
  width: 100%;
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
}
.sideboard-widget:empty {
  display: none;
}
.sideboard__filter-container:has(~ .sideboard__doclist:empty) {
  display: none;
}
.popmenu__trigger,
.popmenu__sub-trigger {
  cursor: default;
  user-select: none;
  width: 100%;
  text-align: left;
}
.popmenu__sub-content,
.popmenu__content {
  z-index: 2;
  min-width: 220px;
  max-height: min(400px, 50vh);
  overflow-y: auto;
  padding: 4px;
  background-color: var(--sideboard-widget-fill);
  font-size: 0.8rem;
  border-radius: 6px;
  border: 1px solid hsl(240 6% 90%);
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  outline: none;
  transform-origin: var(--kb-menu-content-transform-origin);
  animation: contentHide 250ms ease-in forwards;
}
.popmenu__content[data-expanded],
.popmenu__sub-content[data-expanded] {
  animation: contentShow 250ms ease-out;
}
.popmenu__item,
.popmenu__checkbox-item,
.popmenu__radio-item,
.popmenu__sub-trigger {
  font-size: 0.8rem;
  line-height: 1;
  color: var(--sideboard-widget-line);
  border-radius: 4px;
  display: flex;
  align-items: center;
  height: 32px;
  padding-inline: 12px;
  padding-block: 6px;
  position: relative;
  user-select: none;
  outline: none;
  cursor: default;
}
.popmenu__sub-trigger[data-expanded] {
  background-color: var(--sideboard-fill-offset);
  color: var(--sideboard-line);
}
.popmenu__item[data-disabled],
.popmenu__checkbox-item[data-disabled],
.popmenu__radio-item[data-disabled],
.popmenu__sub-trigger[data-disabled] {
  color: hsl(240 5% 65%);
  opacity: 0.5;
  pointer-events: none;
}
.popmenu__item[data-highlighted],
.popmenu__checkbox-item[data-highlighted],
.popmenu__radio-item[data-highlighted],
.popmenu__sub-trigger[data-highlighted] {
  outline: none;
  background-color: color-mix(in oklch, var(--sideboard-primary), var(--sideboard-widget-fill) 20%);
  color: var(--sideboard-widget-line);
}
@keyframes contentShow {
  from {
    opacity: 0;
    transform: scale(0.96);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes contentHide {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0.96);
  }
}
.popmenu__item--highlighted {
  outline: none;
  background-color: color-mix(in oklch, var(--sideboard-primary), var(--sideboard-widget-fill) 20%);
  color: var(--sideboard-widget-line);
}
.create-new-filter {
  padding: 4px;
}
.create-new-filter__input {
  width: 100%;
  box-sizing: border-box;
  padding: 6px 8px;
  font-size: 0.8rem;
  border: 1px solid hsl(240 6% 80%);
  border-radius: 4px;
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
  outline: none;
}
.create-new-filter__input:focus {
  border-color: var(--sideboard-primary);
}
.create-new-filter__input::placeholder {
  color: hsl(240 5% 65%);
}
.share-modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 2rem;
}
.share-modal__content {
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
  border-radius: 8px;
  width: 90vw;
  max-width: 480px;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.15);
  overflow: hidden;
}
.share-modal__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid color-mix(in oklab, var(--sideboard-widget-fill), black 15%);
}
.share-modal__header h2 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 600;
}
.share-modal__close {
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 1.5rem;
  color: var(--sideboard-widget-line);
  width: 2rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: all 0.15s ease;
}
.share-modal__close:hover {
  background: color-mix(in oklab, var(--sideboard-widget-fill), black 10%);
}
.share-modal__body {
  padding: 1.5rem;
  overflow-y: auto;
  flex: 1;
}
.share-modal__public-section {
  margin-bottom: 1rem;
}
.share-modal__public-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.share-modal__public-status {
  font-size: 0.875rem;
  color: var(--sideboard-widget-line);
}
.share-modal__public-actions {
  display: flex;
  gap: 0.5rem;
}
.share-modal__form {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}
.share-modal__form-actions {
  display: flex;
  gap: 0.5rem;
}
.share-modal__input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid color-mix(in oklab, var(--sideboard-widget-fill), black 15%);
  border-radius: 4px;
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
  font-size: 0.875rem;
  font-family:
    "SF Mono",
    "Monaco",
    "Menlo",
    "Consolas",
    monospace;
  resize: vertical;
  min-height: 4rem;
}
.share-modal__input:focus {
  outline: 2px solid var(--sideboard-primary);
  outline-offset: 1px;
}
.share-modal__select {
  padding: 0.5rem 0.75rem;
  border: 1px solid color-mix(in oklab, var(--sideboard-widget-fill), black 15%);
  border-radius: 4px;
  background: var(--sideboard-widget-fill);
  color: var(--sideboard-widget-line);
  font-size: 0.875rem;
}
.share-modal__add-button {
  padding: 0.5rem 1rem;
  border-radius: 4px;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  background: color-mix(in oklch, #3b82f6, white 10%);
  border: 1px solid color-mix(in oklch, #3b82f6, black 5%);
  color: white;
  transition: all 0.15s ease;
}
.share-modal__add-button:hover:not(:disabled) {
  background: #3b82f6;
}
.share-modal__add-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.share-modal__divider {
  border: none;
  border-top: 1px solid color-mix(in oklab, var(--sideboard-widget-fill), black 15%);
  margin: 0 0 1.5rem 0;
}
.share-modal__section-title {
  font-size: 0.875rem;
  font-weight: 600;
  margin: 0 0 1rem 0;
}
.share-modal__loading,
.share-modal__empty {
  font-size: 0.875rem;
  color: color-mix(in oklab, var(--sideboard-widget-line), transparent 40%);
  font-style: italic;
}
.share-modal__error {
  padding: 0.5rem 0.75rem;
  background: color-mix(in oklch, #ef4444, white 80%);
  border: 1px solid color-mix(in oklch, #ef4444, white 60%);
  border-radius: 4px;
  color: #991b1b;
  font-size: 0.875rem;
  margin-bottom: 1rem;
}
.share-modal__member-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.share-modal__member {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem;
  background: color-mix(in oklab, var(--sideboard-widget-fill), black 5%);
  border-radius: 4px;
}
.share-modal__member-info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.share-modal__member-id {
  font-family:
    "SF Mono",
    "Monaco",
    "Menlo",
    "Consolas",
    monospace;
  font-size: 0.8rem;
}
.share-modal__member-id--you {
  font-weight: 600;
}
.share-modal__member-id--public {
  font-weight: 600;
  color: #22c55e;
}
.share-modal__you-label {
  color: var(--sideboard-primary);
  font-weight: 600;
}
.share-modal__member-access {
  font-size: 0.75rem;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--sideboard-widget-line), transparent 30%);
}
.share-modal__remove-button {
  background: transparent;
  border: none;
  cursor: pointer;
  color: color-mix(in oklab, var(--sideboard-widget-line), transparent 40%);
  padding: 0.25rem;
  border-radius: 4px;
  transition: all 0.15s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.share-modal__remove-button:hover {
  color: #ef4444;
  background: color-mix(in oklch, #ef4444, transparent 90%);
}
@media (prefers-color-scheme: dark) {
  .share-modal__header {
    border-bottom-color: color-mix(in oklab, var(--sideboard-widget-fill), white 15%);
  }
  .share-modal__close:hover {
    background: color-mix(in oklab, var(--sideboard-widget-fill), white 10%);
  }
  .share-modal__input,
  .share-modal__select {
    border-color: color-mix(in oklab, var(--sideboard-widget-fill), white 15%);
  }
  .share-modal__divider {
    border-top-color: color-mix(in oklab, var(--sideboard-widget-fill), white 15%);
  }
  .share-modal__member {
    background: color-mix(in oklab, var(--sideboard-widget-fill), white 8%);
  }
  .share-modal__error {
    background: color-mix(in oklch, #ef4444, black 70%);
    border-color: color-mix(in oklch, #ef4444, black 50%);
    color: #fca5a5;
  }
}
/*# sourceMappingURL=index.css.map */


/* ---------- doc-title chrome — from LFC ---------- */
/*   source: extracted/local-first-conf-patchwork-release/styles/07-doc-title.css */
.doc-title{font-weight:400;white-space:nowrap;height:100%;display:flex;align-items:center;cursor:text}.doc-title:hover{opacity:.7}.doc-title-input{display:none;font-weight:400;white-space:nowrap;height:100%;width:100%;background:transparent;outline:none;border:none;font:inherit;color:inherit;padding:0;margin:0;min-width:4em}

/* ---------- add-doc-to-sidebar chrome — from LFC ---------- */
/*   source: extracted/local-first-conf-patchwork-release/styles/02-add-doc-to-sidebar.css */
.add-doc-to-sidebar{display:flex;align-items:center;height:100%;width:fit-content;min-width:0}.add-doc-to-sidebar button{background:none;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;font:inherit}.add-doc-to-sidebar button:hover{background:color-mix(in srgb,currentColor 10%,transparent)}

/* ---------- sidebar-toggle-icon chrome — from LFC ---------- */
/*   source: extracted/local-first-conf-patchwork-release/styles/09-sidebar-toggle-icon.css */
.sidebar-toggle-icon{display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;padding:2px;border-radius:4px;color:inherit;opacity:.5}.sidebar-toggle-icon:hover{opacity:1;background:color-mix(in oklab,currentColor 10%,transparent)}

/* ---------- sync-trigger chrome — from LFC ---------- */
/*   source: extracted/local-first-conf-patchwork-release/styles/13-sync-trigger.css */
.sync-trigger{padding:4px;border-radius:6px;color:#6b7280;vertical-align:top;background:none;border:none;cursor:pointer}.sync-trigger:hover{color:#111827}.sync-trigger-offline{padding:8px;border-radius:6px;color:#6b7280;background:none;border:none;cursor:pointer}.sync-trigger-offline:hover{background:#f3f4f6}.sync-popover-wrapper{display:inline-block}.sync-popover{position:fixed;z-index:2147483647;width:288px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;padding:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;outline:none}.sync-popover-body{display:flex;flex-direction:column;gap:8px}.sync-status-header{font-size:14px;font-weight:600;color:#111827}.sync-peers{display:flex;flex-direction:column;gap:2px}.sync-peer{border:1px solid #e5e7eb;border-radius:4px;padding:6px 8px;font-size:12px;color:#4b5563}.sync-peer-clickable{cursor:pointer}.sync-peer-clickable:hover{background:#f9fafb}.sync-arrow{text-align:center;color:#111827;font-size:12px;line-height:1;margin:.5em 0}.sync-peer-header{display:flex;justify-content:space-between;align-items:center}.sync-peer-name{font-weight:600;color:#111827}.sync-peer-status{font-size:11px;color:#6b7280}.sync-peer-detail{font-size:11px;color:#9ca3af;font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sync-no-peers{font-size:12px;color:#9ca3af;text-align:center;padding:8px 0}.sync-footer{display:flex;justify-content:flex-end;padding-top:4px;border-top:1px solid #e5e7eb}.sync-copy-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:6px;background:none;border:none;cursor:pointer;height:28px;padding:0 8px;font-size:12px}.sync-copy-btn:hover{background:#f3f4f6;color:#111827}

/* ---------- Bullets tool — from WP archive ---------- */
/*   source: extracted/weekly-planning/styles/18-bullets-container.css */
.bullets-container{background:var(--color-base-100, #1d232a);color:var(--color-base-content, #a6adbb);font-family:Merriweather Sans,sans-serif;font-size:16px;line-height:1.5rem;width:100%;height:100%;padding:16px 24px;box-sizing:border-box;position:relative;overflow-x:hidden;overflow-y:auto}.bullets-container.read-only .bullets-list,.bullets-container.read-only .bullets-add-btn,.bullets-container.read-only .bullets-title{pointer-events:none;opacity:.6}.bullets-version-gate{background:#3a2a1a;color:#e8c872;padding:8px 14px;border-radius:4px;font-size:13px;margin-bottom:8px}.bullets-container.file-drag-over:after{content:"";position:absolute;inset:4px;border:2px dashed #4a9eff;border-radius:8px;pointer-events:none;z-index:100}.bullets-top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;border-bottom:1px solid var(--color-base-300, #15191e)}.bullets-nav-bar{display:flex;align-items:center;gap:4px;padding:8px 0}.bullets-nav-btn{background:none;border:none;color:var(--color-base-content, #a6adbb);opacity:.6;cursor:pointer;font-size:13px;padding:2px 6px;border-radius:3px}.bullets-nav-btn:hover{opacity:1;background:var(--color-base-200, #191e24)}.bullets-nav-sep{color:var(--color-base-content, #a6adbb);opacity:.4;font-size:12px}.bullets-title-row{display:flex;align-items:center;gap:8px;margin-bottom:16px}.bullets-home-icon{width:18px;height:18px;flex-shrink:0;color:var(--color-base-content, #a6adbb);opacity:.5}.bullets-context-title{font-family:Merriweather Sans,sans-serif;font-size:1.5rem;line-height:2rem;font-weight:400;color:var(--color-base-content, #a6adbb);margin:0;padding:0;outline:none;flex:1;min-width:0}.bullets-context-title:empty:before{content:"Untitled";color:var(--color-base-content, #a6adbb);opacity:.3;pointer-events:none}.bullets-list{padding:0;position:relative}.bullets-list.drag-selecting{user-select:none}.bullet-item{position:relative}.bullet-row{display:flex;align-items:flex-start;min-height:28px;padding:1px 0}.bullet-row:hover{background:var(--color-base-200, rgba(255, 255, 255, .03));border-radius:3px}.bullet-row.link-row{background:linear-gradient(to right,transparent 36px,rgba(74,144,226,.08) 36px);border-radius:3px}.bullet-row.link-row:hover{background:linear-gradient(to right,transparent 36px,rgba(74,144,226,.12) 36px)}.bullets-title-row.link-row{background:#4a90e214;border-radius:3px}.bullets-title-row.link-row:hover{background:#4a90e21f}.bullet-row.selected{background:#4a9eff26;border-radius:3px}.bullet-controls{display:flex;align-items:center;flex-shrink:0;width:32px;justify-content:flex-end;margin-right:4px;padding-top:3px}.bullet-triangle{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:8px;color:var(--color-base-content, #a6adbb);opacity:.3;cursor:default;user-select:none;flex-shrink:0}.bullet-triangle.has-children{cursor:pointer;opacity:.5}.bullet-triangle.has-children:hover{opacity:.8}.bullet-dot{display:inline-block;width:6px;height:6px;min-width:6px;padding:6px;background:var(--color-base-content, #a6adbb);background-clip:content-box;opacity:.5;border-radius:50%;margin-right:-4px;margin-left:-2px;flex-shrink:0;cursor:pointer;box-sizing:content-box;position:relative}.bullet-dot.has-collapsed-children:after{content:"";position:absolute;top:50%;left:50%;width:6px;height:6px;transform:translate(-50%,-50%);border-radius:50%;box-shadow:0 0 0 3px #80808099;pointer-events:none}.bullet-dot.mirrored{border-radius:1px;transform:rotate(45deg)}.bullet-dot:hover{opacity:.8}.bullet-content{flex:1;outline:none;padding:0 4px;min-height:1.5rem;word-wrap:break-word;overflow-wrap:break-word;white-space:pre-wrap;cursor:text;line-height:1.5rem}.bullet-content:focus{background:var(--color-base-200, rgba(255, 255, 255, .04));border-radius:2px}.bullet-children{margin-left:18px;padding-left:9px;border-left:1px solid var(--color-base-300, #15191e)}.bullets-add-btn{background:none;border:none;color:var(--color-base-content, #a6adbb);opacity:.3;font-size:30px;cursor:pointer;padding:0;margin-top:4px;margin-left:18px;line-height:1}.bullets-add-btn:hover{opacity:.6}.bullets-context-menu{position:absolute;background:var(--color-base-200, #191e24);border:1px solid var(--color-base-300, #15191e);border-radius:6px;padding:4px 0;min-width:140px;box-shadow:0 4px 12px #0006;z-index:1000}.bullets-context-menu-item{display:block;width:100%;background:none;border:none;color:var(--color-base-content, #a6adbb);font-size:13px;padding:6px 14px;text-align:left;cursor:pointer}.bullets-context-menu-item:hover{background:var(--color-base-300, #15191e)}.bullet-item.dragging{opacity:.25}.bullets-drop-indicator{position:absolute;height:2px;background:#4a9eff;pointer-events:none;z-index:10;border-radius:1px}.bullets-drop-indicator:before{content:"";position:absolute;left:-4px;top:-3px;width:8px;height:8px;border-radius:50%;background:#4a9eff}.bullet-tag{color:#a78bfa;cursor:pointer}.bullet-tag:hover{text-decoration:underline}.bullets-tag-header{font-size:1.25rem;font-weight:500;color:#a78bfa;margin-bottom:12px}.bullets-tag-result{padding:6px 8px;cursor:pointer;font-size:14px;color:var(--color-base-content, #a6adbb);border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bullets-tag-result:hover{background:var(--color-base-300, #15191e)}.bullet-link{color:#7ab4f5;text-decoration:underline;text-decoration-color:#7ab4f566;cursor:pointer}.bullet-link:hover{text-decoration-color:#7ab4f5}.bullet-content.link-hidden{position:absolute;opacity:0;width:0;min-height:0;padding:0;overflow:hidden;pointer-events:none}.bullet-content.automerge-url{font-family:monospace;font-size:13px}.bullet-content.image-label{color:var(--color-base-content, #a6adbb);opacity:.55;font-style:italic}.bullets-context-title.link-hidden{position:absolute;opacity:0;width:0;min-height:0;padding:0;overflow:hidden;pointer-events:none}.bullets-context-title.image-label{color:var(--color-base-content, #a6adbb);opacity:.55;font-style:italic}.bullet-am-title{flex:1;min-width:0;font-size:16px;line-height:1.5rem;color:var(--color-base-content, #a6adbb);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 4px;cursor:text}.bullets-context-am-title{flex:1;min-width:0;font-family:Merriweather Sans,sans-serif;font-size:1.5rem;line-height:2rem;font-weight:400;color:var(--color-base-content, #a6adbb);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:text}.embed-toggle{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:10px;color:#7ab4f5;opacity:.7;cursor:pointer;user-select:none;flex-shrink:0;margin-right:2px;border-radius:3px}.embed-toggle:hover{opacity:1;background:#4a90e226}.automerge-embed-wrapper{margin-left:18px;padding-left:9px;border-left:1px solid var(--color-base-300, #15191e);margin-top:4px;margin-bottom:4px}.automerge-embed-wrapper.context-embed{margin-left:0;padding-left:0;border-left:none;margin-bottom:12px}.embed-blocked{color:var(--color-base-content, #a6adbb);opacity:.5;font-size:13px;font-style:italic;padding:8px 12px}.automerge-embed-container{border:1px solid var(--color-base-content, #a6adbb);border-radius:4px;overflow:hidden;height:400px}.youtube-embed{width:100%;aspect-ratio:16 / 9;border:none;border-radius:4px}.bullet-image-embed{max-width:100%;border-radius:4px}.bullets-search-btn{background:none;border:none;color:var(--color-base-content, #a6adbb);opacity:.5;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bullets-search-btn:hover,.bullets-search-btn.active{opacity:1;background:var(--color-base-200, #191e24)}.bullets-info-btn{background:none;border:none;color:var(--color-base-content, #a6adbb);opacity:.5;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bullets-info-btn:hover,.bullets-info-btn.active{opacity:1;background:var(--color-base-200, #191e24)}.bullets-info-panel{background:var(--color-base-200, #191e24);border:1px solid var(--color-base-300, #15191e);border-radius:6px;padding:12px 14px;margin-bottom:12px;box-shadow:0 4px 12px #0000004d;font-size:13px;line-height:1.5}.bullets-info-title{font-size:15px;font-weight:600;color:var(--color-base-content, #a6adbb);margin-bottom:4px}.bullets-info-section{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-base-content, #a6adbb);opacity:.5;margin-top:8px;margin-bottom:2px}.bullets-info-text{color:var(--color-base-content, #a6adbb);opacity:.7}.bullets-info-text b{opacity:1;color:var(--color-base-content, #a6adbb)}.bullets-search-panel{background:var(--color-base-200, #191e24);border:1px solid var(--color-base-300, #15191e);border-radius:6px;padding:8px;margin-bottom:12px;box-shadow:0 4px 12px #0000004d;max-height:350px;overflow-y:auto}.bullets-search-input{width:100%;background:var(--color-base-100, #1d232a);border:1px solid var(--color-base-300, #15191e);border-radius:4px;color:var(--color-base-content, #a6adbb);font-family:Merriweather Sans,sans-serif;font-size:14px;padding:6px 10px;outline:none;box-sizing:border-box}.bullets-search-input:focus{border-color:#4a9eff}.bullets-search-empty{font-size:13px;color:var(--color-base-content, #a6adbb);opacity:.4;padding:8px 6px;font-style:italic}.bullets-search-result{padding:6px;cursor:pointer;font-size:14px;color:var(--color-base-content, #a6adbb);border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bullets-search-result:hover,.bullets-search-result.selected{background:var(--color-base-300, #15191e)}.bullets-search-match{background:#4a9eff40;border-radius:2px}.bullets-hamburger{background:none;border:none;color:var(--color-base-content, #a6adbb);opacity:.5;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bullets-hamburger:hover,.bullets-hamburger.active{opacity:1;background:var(--color-base-200, #191e24)}.bullets-favorites-panel{position:relative;background:var(--color-base-200, #191e24);border:1px solid var(--color-base-300, #15191e);border-radius:6px;padding:8px 0;margin-bottom:12px;box-shadow:0 4px 12px #0000004d}.bullets-favorites-header{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-base-content, #a6adbb);opacity:.5;padding:4px 14px 8px}.bullets-favorites-empty{font-size:13px;color:var(--color-base-content, #a6adbb);opacity:.4;padding:8px 14px;font-style:italic}.bullets-favorites-item{display:flex;align-items:center;padding:6px 14px;cursor:pointer;gap:8px}.bullets-favorites-item:hover{background:var(--color-base-300, #15191e)}.bullets-favorites-item-text{flex:1;font-size:14px;color:var(--color-base-content, #a6adbb);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.bullet-star{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--color-base-content, #a6adbb);opacity:0;cursor:pointer;flex-shrink:0;margin-left:4px;border-radius:3px;transition:opacity .1s}.bullet-row:hover .bullet-star{opacity:.3}.bullet-row:hover .bullet-star:hover{opacity:.7}.bullet-star.starred{opacity:.7;color:#f5c842}.bullet-star.starred:hover{opacity:1}.bullet-row:hover .bullet-star.starred{opacity:.7}.bullet-row:hover .bullet-star.starred:hover{opacity:1}.bullet-item.completed .bullet-content{text-decoration:line-through;opacity:.4}.bullet-item.completed .bullet-dot{opacity:.25}.bullet-row.completed{opacity:.6}.bullets-completed-btn{background:none;border:none;color:var(--color-base-content, #a6adbb);opacity:.35;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bullets-completed-btn:hover{opacity:.7;background:var(--color-base-200, #191e24)}.bullets-completed-btn.active{opacity:1;color:#4ade80;background:var(--color-base-200, #191e24)}.bullets-mobile-toolbar{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-evenly;background:var(--color-base-200, #191e24);border-top:1px solid var(--color-base-300, #15191e);padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom));z-index:1000;box-shadow:0 -2px 8px #0000004d}.bullets-mobile-toolbar-btn{background:none;border:1px solid var(--color-base-300, #15191e);color:var(--color-base-content, #a6adbb);cursor:pointer;padding:10px 14px;border-radius:8px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.bullets-mobile-toolbar-btn:active{background:var(--color-base-300, #15191e)}.bullets-container.mobile-toolbar-active{padding-bottom:70px}.bullets-favorites-item.dragging{opacity:.25}.bullets-fav-drop-indicator{position:absolute;height:2px;background:#4a9eff;pointer-events:none;z-index:10;border-radius:1px}.bullets-fav-drop-indicator:before{content:"";position:absolute;left:-4px;top:-3px;width:8px;height:8px;border-radius:50%;background:#4a9eff}

/* ---------- CodeMirror styles (markdown editor) — from LFC ---------- */
/*   source: extracted/local-first-conf-patchwork-release/styles/00-ͼ1.cm-focused.css */
.ͼ1.cm-focused {outline: 1px dotted #212121;}
.ͼ1 {position: relative !important; box-sizing: border-box; display: flex !important; flex-direction: column;}
.ͼ1 .cm-scroller {display: flex !important; align-items: flex-start !important; font-family: monospace; line-height: 1.4; height: 100%; overflow-x: auto; position: relative; z-index: 0; overflow-anchor: none;}
.ͼ1 .cm-content[contenteditable=true] {-webkit-user-modify: read-write-plaintext-only;}
.ͼ1 .cm-content {margin: 0; flex-grow: 2; flex-shrink: 0; display: block; white-space: pre; word-wrap: normal; box-sizing: border-box; min-height: 100%; padding: 4px 0; outline: none;}
.ͼ1 .cm-lineWrapping {white-space: pre-wrap; white-space: break-spaces; word-break: break-word; overflow-wrap: anywhere; flex-shrink: 1;}
.ͼ2 .cm-content {caret-color: black;}
.ͼ3 .cm-content {caret-color: white;}
.ͼ1 .cm-line {display: block; padding: 0 2px 0 6px;}
.ͼ1 .cm-layer > * {position: absolute;}
.ͼ1 .cm-layer {position: absolute; left: 0; top: 0; contain: size style;}
.ͼ2 .cm-selectionBackground {background: #d9d9d9;}
.ͼ3 .cm-selectionBackground {background: #222;}
.ͼ2.cm-focused > .cm-scroller > .cm-selectionLayer .cm-selectionBackground {background: #d7d4f0;}
.ͼ3.cm-focused > .cm-scroller > .cm-selectionLayer .cm-selectionBackground {background: #233;}
.ͼ1 .cm-cursorLayer {pointer-events: none;}
.ͼ1.cm-focused > .cm-scroller > .cm-cursorLayer {animation: steps(1) cm-blink 1.2s infinite;}
@keyframes cm-blink {50% {opacity: 0;}}
@keyframes cm-blink2 {50% {opacity: 0;}}
.ͼ1 .cm-cursor, .ͼ1 .cm-dropCursor {border-left: 1.2px solid black; margin-left: -0.6px; pointer-events: none;}
.ͼ1 .cm-cursor {display: none;}
.ͼ3 .cm-cursor {border-left-color: #ddd;}
.ͼ1 .cm-selectionHandle {background-color: currentColor; width: 1.5px;}
.ͼ1 .cm-selectionHandle-start::before, .ͼ1 .cm-selectionHandle-end::before {content: ""; background-color: inherit; border-radius: 50%; width: 8px; height: 8px; position: absolute; left: -3.25px;}
.ͼ1 .cm-selectionHandle-start::before {top: -8px;}
.ͼ1 .cm-selectionHandle-end::before {bottom: -8px;}
.ͼ1 .cm-dropCursor {position: absolute;}
.ͼ1.cm-focused > .cm-scroller > .cm-cursorLayer .cm-cursor {display: block;}
.ͼ1 .cm-iso {unicode-bidi: isolate;}
.ͼ1 .cm-announced {position: fixed; top: -10000px;}
@media print {.ͼ1 .cm-announced {display: none;}}
.ͼ2 .cm-activeLine {background-color: #cceeff44;}
.ͼ3 .cm-activeLine {background-color: #99eeff33;}
.ͼ2 .cm-specialChar {color: red;}
.ͼ3 .cm-specialChar {color: #f78;}
.ͼ1 .cm-gutters {flex-shrink: 0; display: flex; height: 100%; box-sizing: border-box; z-index: 200;}
.ͼ1 .cm-gutters-before {inset-inline-start: 0;}
.ͼ1 .cm-gutters-after {inset-inline-end: 0;}
.ͼ2 .cm-gutters.cm-gutters-before {border-right-width: 1px;}
.ͼ2 .cm-gutters.cm-gutters-after {border-left-width: 1px;}
.ͼ2 .cm-gutters {background-color: #f5f5f5; color: #6c6c6c; border: 0px solid #ddd;}
.ͼ3 .cm-gutters {background-color: #333338; color: #ccc;}
.ͼ1 .cm-gutter {display: flex !important; flex-direction: column; flex-shrink: 0; box-sizing: border-box; min-height: 100%; overflow: hidden;}
.ͼ1 .cm-gutterElement {box-sizing: border-box;}
.ͼ1 .cm-lineNumbers .cm-gutterElement {padding: 0 3px 0 5px; min-width: 20px; text-align: right; white-space: nowrap;}
.ͼ2 .cm-activeLineGutter {background-color: #e2f2ff;}
.ͼ3 .cm-activeLineGutter {background-color: #222227;}
.ͼ1 .cm-panels {box-sizing: border-box; position: sticky; left: 0; right: 0; z-index: 300;}
.ͼ2 .cm-panels {background-color: #f5f5f5; color: black;}
.ͼ2 .cm-panels-top {border-bottom: 1px solid #ddd;}
.ͼ2 .cm-panels-bottom {border-top: 1px solid #ddd;}
.ͼ3 .cm-panels {background-color: #333338; color: white;}
.ͼ1 .cm-dialog label {font-size: 80%;}
.ͼ1 .cm-dialog {padding: 2px 19px 4px 6px; position: relative;}
.ͼ1 .cm-dialog-close {position: absolute; top: 3px; right: 4px; background-color: inherit; border: none; font: inherit; font-size: 14px; padding: 0;}
.ͼ1 .cm-tab {display: inline-block; overflow: hidden; vertical-align: bottom;}
.ͼ1 .cm-widgetBuffer {vertical-align: text-top; height: 1em; width: 0; display: inline;}
.ͼ1 .cm-placeholder {color: #888; display: inline-block; vertical-align: top; user-select: none;}
.ͼ1 .cm-highlightSpace {background-image: radial-gradient(circle at 50% 55%, #aaa 20%, transparent 5%); background-position: center;}
.ͼ1 .cm-highlightTab {background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="200" height="20"><path stroke="%23888" stroke-width="1" fill="none" d="M1 10H196L190 5M190 15L196 10M197 4L197 16"/></svg>'); background-size: auto 100%; background-position: right 90%; background-repeat: no-repeat;}
.ͼ1 .cm-trailingSpace {background-color: #ff332255;}
.ͼ1 .cm-button {vertical-align: middle; color: inherit; font-size: 70%; padding: .2em 1em; border-radius: 1px;}
.ͼ2 .cm-button:active {background-image: linear-gradient(#b4b4b4, #d0d3d6);}
.ͼ2 .cm-button {background-image: linear-gradient(#eff1f5, #d9d9df); border: 1px solid #888;}
.ͼ3 .cm-button:active {background-image: linear-gradient(#111, #333);}
.ͼ3 .cm-button {background-image: linear-gradient(#393939, #111); border: 1px solid #888;}
.ͼ1 .cm-textfield {vertical-align: middle; color: inherit; font-size: 70%; border: 1px solid silver; padding: .2em .5em;}
.ͼ2 .cm-textfield {background-color: white;}
.ͼ3 .cm-textfield {border: 1px solid #555; background-color: inherit;}
.ͼ1 .cm-link {text-decoration: underline; cursor: pointer; font-family: "Merriweather Sans", sans-serif;}
.ͼ2 .cm-link:hover {color: inherit;}
.ͼ2 .cm-link {color: #0066cc;}
.ͼ3 .cm-link:hover {color: inherit;}
.ͼ3 .cm-link {color: #3399ff;}
.ͼ1 .cm-embed {display: block; border: 1px solid; border-radius: 4px; overflow: hidden;}
.ͼ2 .cm-embed {border-color: #ddd;}
.ͼ3 .cm-embed {border-color: #333;}
.ͼ1 .cm-embed-label {font-family: monospace; padding: 4px 8px; border-bottom: 1px solid; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; cursor: text; display: flex; align-items: center; gap: 8px;}
.ͼ1 .cm-embed-label-text:hover {opacity: 1;}
.ͼ1 .cm-embed-label-text {flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; opacity: 0.7;}
.ͼ1 .cm-embed-open-link:hover {opacity: 1;}
.ͼ1 .cm-embed-open-link {display: inline-flex; align-items: center; justify-content: center; width: 16px; height: 16px; cursor: pointer; flex-shrink: 0; border: none; background: none; padding: 0; color: inherit; opacity: 0.7;}
.ͼ2 .cm-embed-label {border-bottom-color: #ddd;}
.ͼ3 .cm-embed-label {border-bottom-color: #333;}
.ͼ1 .cm-embed patchwork-view {display: block; height: 500px; width: 100%;}
.ͼ1 .cm-embed patchwork-view > * {height: 100%; width: 100%;}
.ͼ36 {font-family: "Merriweather Sans", sans-serif;}
.ͼ37 {font-family: "Merriweather Sans", sans-serif; font-weight: 400; text-decoration: none; font-size: 1.5rem; line-height: 2rem; margin-bottom: 1rem; margin-top: 2rem;}
.ͼ38 {font-family: "Merriweather Sans", sans-serif; font-weight: 400; text-decoration: none; font-size: 1.5rem; line-height: 2rem; margin-bottom: 1rem; margin-top: 2rem;}
.ͼ39 {font-family: "Merriweather Sans", sans-serif; font-weight: 400; text-decoration: none; font-size: 1.25rem; line-height: 1.75rem; margin-bottom: 1rem; margin-top: 2rem;}
.ͼ3a {font-family: "Merriweather Sans", sans-serif; font-weight: 400; text-decoration: none; font-size: 1.1rem; margin-bottom: 1rem; margin-top: 2rem;}
.ͼ3b {color: #555; font-family: monospace;}
.ͼ3c {font-style: italic;}
.ͼ3d {font-weight: bold;}
.ͼ3e {font-style: italic;}
.ͼ3f {text-decoration: line-through;}
.ͼ3g {font-weight: 300; color: #999; font-family: "Merriweather Sans", sans-serif;}
.ͼ3h {font-family: monospace; font-size: 1em; color: #708;}
.ͼ3i {font-family: monospace; font-size: 1em; color: var(--color-secondary);}
.ͼ3j {font-family: monospace; font-size: 1em; color: #164;}
.ͼ3k {font-family: monospace; font-size: 1em; color: #5f67b5;}
.ͼ3l {font-family: monospace; font-size: 1em; color: #e40;}
.ͼ3m {font-family: monospace; font-size: 1em; color: #00f;}
.ͼ3n {font-family: monospace; font-size: 1em; color: #30a;}
.ͼ3o {font-family: monospace; font-size: 1em; color: #085;}
.ͼ3p {font-family: monospace; font-size: 1em; color: #167;}
.ͼ3q {font-family: monospace; font-size: 1em; color: #256;}
.ͼ3r {font-family: monospace; font-size: 1em; color: #00c;}
.ͼ3s {font-family: monospace; font-size: 1em;}
.ͼ35.cm-editor.cm-focused {outline: none;}
.ͼ35.cm-editor {height: 100%; display: flex; align-content: center; justify-content: center; overflow: auto;}
.ͼ35 .cm-scroller {background: var(--color-base);}
.ͼ35 .cm-gutter {background: transparent;}
.ͼ35 .cm-content {text-wrap: pretty; line-height: 1.5rem; color: var(--color-base-content); caret-color: var(--color-base-content); background: var(--color-base-100); margin-block: 2rem; margin-inline: auto; max-width: calc(var(--max-text-line-width) - 2rem); padding: 2rem; box-shadow: none; margin-bottom: 8em; border-radius: 8px;}
.ͼ35 .cm-content li {margin-bottom: 0;}
.ͼ35 .cm-activeLine {background-color: inherit;}
.ͼ35 .frontmatter, .ͼ35 .frontmatter * {font-size: 14px; font-family: monospace; color: #666; text-decoration: none; font-weight: normal; line-height: 0.8em;}
.ͼ35 .cm-gutters {border-right: 0; border: 0; background: var(--color-base-100);}
.ͼ35 .cm-comment-gutter {width: 20px;}
.ͼ35 .cm-folded-range-gutter-line-number {display: none;}
.ͼ35 .cm-folded-range-gutter {background: var(--color-base-100); border-right: 0px; width: 40px;}
.ͼ35 .cm-folded-line-widget {background: var(--color-base-100); border: 0px;}
.ͼ35 .cm-folded-range {background: var(--color-base-100);}
.ͼ35 .codeblock {background: orange;}
patchwork-view patchwork-view patchwork-view .ͼ35 .cm-content {margin: 0; padding: 1em; max-width: none; border-radius: 0;}
patchwork-view patchwork-view patchwork-view .p-4:has(.ͼ35) {padding: 0;}


/* ---------- Bootloader keyframes — from LFC ---------- */
/*   source: extracted/local-first-conf-patchwork-release/styles/01-keyframes.css */

      @keyframes pw-bootloader-pulse {
        0%, 100% { opacity: 0.25; }
        50% { opacity: 0.95; }
      }
      #pw-bootloader-loading {
        position: fixed;
        inset: 0;
        z-index: 0;
        pointer-events: none;
        background-color: #fff;
        background-image:
          radial-gradient(ellipse 55% 45% at 28% 35%, #fde4ec, transparent 70%),
          radial-gradient(ellipse 50% 55% at 72% 65%, #e0f0fb, transparent 70%),
          radial-gradient(ellipse 65% 55% at 50% 50%, #f1e6f6, transparent 80%);
        animation: pw-bootloader-pulse 3.5s ease-in-out infinite;
        transition: opacity 0.6s ease-out;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
      }
      @media (prefers-color-scheme: dark) {
        #pw-bootloader-loading {
          background-color: #000;
          background-image:
            radial-gradient(ellipse 55% 45% at 28% 35%, #2a1d33, transparent 70%),
            radial-gradient(ellipse 50% 55% at 72% 65%, #1a2738, transparent 70%),
            radial-gradient(ellipse 65% 55% at 50% 50%, #221a2e, transparent 80%);
        }
      }
      #pw-bootloader-loading.pw-bootloader-fading {
        opacity: 0;
        animation: none;
      }
    

