/*! tailwindcss v4.1.11 | 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-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-scroll-snap-strictness: proximity;
      --tw-border-style: solid;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-tracking: 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;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-backdrop-blur: initial;
      --tw-backdrop-brightness: initial;
      --tw-backdrop-contrast: initial;
      --tw-backdrop-grayscale: initial;
      --tw-backdrop-hue-rotate: initial;
      --tw-backdrop-invert: initial;
      --tw-backdrop-opacity: initial;
      --tw-backdrop-saturate: initial;
      --tw-backdrop-sepia: initial;
      --tw-duration: initial;
      --tw-ease: initial;
      --tw-scale-x: 1;
      --tw-scale-y: 1;
      --tw-scale-z: 1;
    }
  }
}

@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-red-500: oklch(63.7% .237 25.331);
    --color-gray-500: oklch(55.1% .027 264.364);
    --color-white: #fff;
    --spacing: .25rem;
    --container-lg: 32rem;
    --container-xl: 36rem;
    --container-3xl: 48rem;
    --container-6xl: 72rem;
    --container-7xl: 80rem;
    --text-xs--line-height: calc(1 / .75);
    --text-sm--line-height: calc(1.25 / .875);
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --text-5xl: 3rem;
    --text-5xl--line-height: 1;
    --text-6xl: 3.75rem;
    --text-6xl--line-height: 1;
    --text-9xl: 8rem;
    --text-9xl--line-height: 1;
    --font-weight-light: 300;
    --font-weight-medium: 500;
    --font-weight-bold: 700;
    --font-weight-black: 900;
    --tracking-wide: .025em;
    --leading-tight: 1.25;
    --leading-relaxed: 1.625;
    --ease-in-out: cubic-bezier(.4, 0, .2, 1);
    --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%;
    -moz-tab-size: 4;
      -o-tab-size: 4;
         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;
  }

  ::-moz-placeholder {
    opacity: 1;
  }

  ::placeholder {
    opacity: 1;
  }

  @supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px) {
    ::-moz-placeholder {
      color: currentColor;
    }
    ::placeholder {
      color: currentColor;
    }

    @supports (color: color-mix(in lab, red, red)) {
      ::-moz-placeholder {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
      ::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;
  }

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

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

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

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

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

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

@layer components {
  .site-logo {
    font-size: var(--site-logo-height);
    letter-spacing: .05em;
    height: var(--site-logo-height);
    font-weight: 700;
    line-height: var(--site-logo-height);
    flex-shrink: 0;
    align-items: center;
    width: auto;
    text-decoration: none;
    display: inline-flex;
  }

  .site-logo .logo-dark {
    display: none;
  }

  .site-logo img {
    min-height: var(--site-logo-height);
    height: var(--site-logo-height);
    -o-object-fit: contain;
       object-fit: contain;
    width: auto;
    max-width: 100%;
  }

  .site-title {
    font-size: inherit;
    line-height: inherit;
    display: inline-block;
  }

  [data-color-scheme="dark"] .site-logo:has(img.logo-dark) .logo {
    display: none;
  }

  [data-color-scheme="dark"] .site-logo:has(img.logo-dark) .logo-dark {
    display: block;
  }

  .site-header {
    height: var(--site-header-height);
    padding: 0 var(--content-padding-x);
    width: 100%;
    font-family: var(--font-family-body);
    font-weight: var(--font-weight-body);
    background-color: var(--bg-color-0);
    z-index: 20;
    border-bottom: 1px solid var(--border-color-0);
    color: var(--text-color-0);
    margin: 0 auto;
    justify-content: space-between;
    align-items: center;
    gap: 2rem;
    margin-bottom: 2rem;
    display: flex;
    position: relative;
  }

  .site-header .site-logo {
    flex-grow: 1;
  }

  .site-header .nav-actions {
    flex-grow: 1;
    justify-content: flex-end;
    align-items: center;
    gap: .5rem;
    display: flex;
  }

  @media (max-width: 768px) {
    [data-nav-container] {
      top: var(--site-header-height);
      width: 100%;
      height: calc(100dvh - var(--site-header-height));
      background-color: var(--bg-color-0);
      z-index: 100;
      flex-direction: column;
      gap: 1rem;
      padding: 1rem;
      display: none;
      position: absolute;
      left: 0;
    }

    [data-nav-toggle] {
      cursor: pointer;
      border-radius: 50%;
      width: 2.5rem;
      height: 2.5rem;
      padding: .5rem;
      position: relative;
    }

    [data-nav-toggle] span, [data-nav-toggle]:before, [data-nav-toggle]:after {
      content: "";
      background: currentColor;
      border-radius: 1rem;
      width: 1.5rem;
      height: 2px;
      transition: transform .2s ease-in-out;
      display: block;
      position: absolute;
    }

    [data-nav-toggle] span {
      margin-top: -1px;
      top: 50%;
    }

    [data-nav-toggle]:before {
      transform-origin: 0;
      width: 1rem;
      top: .75rem;
    }

    [data-nav-toggle]:after {
      transform-origin: 100%;
      width: .75rem;
      bottom: .75rem;
    }

    body[data-nav-open="true"] [data-nav-container] {
      display: flex;
    }

    body[data-nav-open="true"] [data-nav-toggle] span {
      transform: rotate(-45deg);
    }

    body[data-nav-open="true"] [data-nav-toggle]:before {
      transform: translate(.175rem, -.125rem)rotate(45deg);
    }

    body[data-nav-open="true"] [data-nav-toggle]:after {
      transform: translate(.525rem, .125rem)rotate(45deg);
    }
  }

  @media not all and (min-width: 768px) {
    body {
      overflow-x: hidden;
    }
  }

  body[data-nav-open="true"] {
    overflow: hidden;
  }

  body [data-ghost-search] {
    z-index: 1;
  }

  body [data-ghost-search]:after {
    content: "";
    opacity: .15;
    -webkit-backdrop-filter: blur(.25rem);
    backdrop-filter: blur(.25rem);
    background: radial-gradient(circle, #00000080 0%, #0000 100%);
    border-radius: 50%;
    transition: opacity .22s ease-out, transform .25s ease-out;
    display: block;
    position: absolute;
    inset: -175vmax;
    transform: scale(0);
  }

  body:has(#sodo-search-root:not(:empty)) [data-ghost-search]:after {
    opacity: 1;
    transition: all .3s ease-out;
    transform: scale(1);
  }

  .nav {
    text-wrap: nowrap;
    display: flex;
  }

  .nav-item, .menu-item, .submenu-item {
    cursor: pointer;
    align-items: center;
    gap: .25rem;
    padding: .25rem 1rem;
    display: flex;
    position: relative;
  }

  :is(.nav-item, .menu-item, .submenu-item)[role="button"] {
    z-index: 1;
    position: relative;
  }

  .nav-item-with-menu, .menu-item-with-submenu {
    position: relative;
  }

  :is(.nav-item-with-menu, .menu-item-with-submenu) [role="button"] [role="presentation"] {
    opacity: .3;
    font-weight: 900;
    transition: transform .2s ease-in-out;
    transform: scaleX(1.25)scaleY(.75);
  }

  @keyframes menu-item-animation {
    from {
      opacity: 0;
      transform: translateY(.25rem);
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  @media (min-width: 768px) {
    .nav {
      flex-wrap: wrap;
    }

    nav > :not(:last-child) {
      border-right: 1px solid var(--border-color-0);
      margin-right: -1px;
    }

    :is(.nav-item, .menu-item, .submenu-item):is(a):hover, :is(.nav-item, .menu-item, .submenu-item)[role="button"]:hover span:first-child:not([data-icon="more"]) {
      text-underline-offset: .25rem;
      text-decoration: underline;
    }

    .menu, .submenu {
      background-color: var(--bg-color-0);
      border: 1px solid var(--border-color-0);
      opacity: 0;
      visibility: hidden;
      flex-direction: column;
      gap: .5rem;
      width: -moz-fit-content;
      width: fit-content;
      min-width: calc(100% + 1px);
      padding: .75rem 0;
      display: flex;
      position: absolute;
      transform: translateY(.25rem);
    }

    .menu {
      border-top: none;
      padding: .75rem 0;
      top: 2.4rem;
      left: 0;
    }

    .submenu {
      position: absolute;
      top: -.75rem;
      left: 100%;
    }

    :is(.nav-item-with-menu:hover, .nav-item-with-menu:focus, .nav-item-with-menu:focus-within) > .menu {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
    }

    :is(.nav-item-with-menu:hover, .nav-item-with-menu:focus, .nav-item-with-menu:focus-within) .menu-item {
      display: flex;
    }

    .nav-item-with-menu {
      margin-bottom: -1rem;
    }

    :is(.nav-item-with-menu:hover, .nav-item-with-menu:focus, .nav-item-with-menu:focus-within) > [role="button"] > [role="presentation"] {
      transform: scaleX(1.25)scaleY(-.75);
    }

    :is(.menu-item-with-submenu:hover, .menu-item-with-submenu:focus, .menu-item-with-submenu:focus-within) > [role="button"] > [role="presentation"] {
      transform: rotate(-90deg)scaleX(1.25)scaleY(.75);
    }

    :is(.menu-item-with-submenu:hover, .menu-item-with-submenu:focus, .menu-item-with-submenu:focus-within) > .submenu {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
    }

    :is(.menu-item-with-submenu:hover, .menu-item-with-submenu:focus, .menu-item-with-submenu:focus-within) .submenu-item {
      display: flex;
    }

    .menu-item, .submenu-item {
      animation: .2s ease-out both menu-item-animation;
      display: none;
    }

    :is(.menu-item, .submenu-item):first-child {
      animation-delay: 30ms;
    }

    :is(.menu-item, .submenu-item):nth-child(2) {
      animation-delay: 60ms;
    }

    :is(.menu-item, .submenu-item):nth-child(3) {
      animation-delay: 90ms;
    }

    :is(.menu-item, .submenu-item):nth-child(4) {
      animation-delay: .12s;
    }

    :is(.menu-item, .submenu-item):nth-child(5) {
      animation-delay: .15s;
    }

    :is(.menu-item, .submenu-item):nth-child(6) {
      animation-delay: .18s;
    }

    :is(.menu-item, .submenu-item):nth-child(7) {
      animation-delay: .21s;
    }

    :is(.menu-item, .submenu-item):nth-child(8) {
      animation-delay: .24s;
    }

    :is(.menu-item, .submenu-item):nth-child(9) {
      animation-delay: .27s;
    }

    :is(.menu-item, .submenu-item):nth-child(10) {
      animation-delay: .3s;
    }

    :is(.menu-item, .submenu-item):nth-child(11) {
      animation-delay: .33s;
    }

    :is(.menu-item, .submenu-item):nth-child(12) {
      animation-delay: .36s;
    }
  }

  @media (max-width: 768px) {
    .nav {
      flex-direction: column;
      gap: .75rem;
    }

    .nav-item {
      width: 100%;
    }

    :is(.nav-item-with-menu:focus, .nav-item-with-menu:focus, .nav-item-with-menu:focus-within) > [role="button"] > [role="presentation"] {
      transform: scaleX(1.25)scaleY(-.75);
    }

    :is(.nav-item-with-menu:focus, .nav-item-with-menu:focus, .nav-item-with-menu:focus-within) > .menu, :is(.nav-item-with-menu:focus, .nav-item-with-menu:focus, .nav-item-with-menu:focus-within) .menu-item {
      display: flex;
    }

    .menu {
      flex-direction: column;
      gap: .5rem;
      padding: .5rem 2rem;
      display: none;
    }

    .nav-item, .nav-item-with-menu, .menu-item, .submenu-item {
      animation: .2s ease-out both menu-item-animation;
    }

    @starting-style {
      .nav-item, .nav-item-with-menu, .menu-item, .submenu-item {
        opacity: 0;
      }
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):first-child {
      animation-delay: 50ms;
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):nth-child(2) {
      animation-delay: .1s;
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):nth-child(3) {
      animation-delay: .15s;
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):nth-child(4) {
      animation-delay: .2s;
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):nth-child(5) {
      animation-delay: .25s;
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):nth-child(6) {
      animation-delay: .3s;
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):nth-child(7) {
      animation-delay: .35s;
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):nth-child(8) {
      animation-delay: .4s;
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):nth-child(9) {
      animation-delay: .45s;
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):nth-child(10) {
      animation-delay: .5s;
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):nth-child(11) {
      animation-delay: .55s;
    }

    :is(.nav-item, .nav-item-with-menu, .menu-item, .submenu-item):nth-child(12) {
      animation-delay: .6s;
    }
  }

  secondary-nav {
    width: 100%;
    display: block;
  }

  secondary-nav nav {
    width: 100%;
  }

  @keyframes secondary-nav-item-animation {
    from {
      opacity: 0;
      transform: translateY(.25rem);
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  @media (max-width: 640px) {
    secondary-nav nav {
      grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
  }

  @media (min-width: 641px) and (max-width: 1024px) {
    secondary-nav nav {
      grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
    }
  }

  secondary-nav nav > div {
    min-width: 0;
  }

  secondary-nav a {
    animation: .2s ease-out both secondary-nav-item-animation;
    display: inline-block;
  }

  secondary-nav a:first-child {
    animation-delay: 50ms;
  }

  secondary-nav a:nth-child(2) {
    animation-delay: .1s;
  }

  secondary-nav a:nth-child(3) {
    animation-delay: .15s;
  }

  secondary-nav a:nth-child(4) {
    animation-delay: .2s;
  }

  secondary-nav a:nth-child(5) {
    animation-delay: .25s;
  }

  secondary-nav a:nth-child(6) {
    animation-delay: .3s;
  }

  secondary-nav a:nth-child(7) {
    animation-delay: .35s;
  }

  secondary-nav a:nth-child(8) {
    animation-delay: .4s;
  }

  secondary-nav a[target="_blank"]:after {
    content: "";
    opacity: .6;
    vertical-align: middle;
    background-color: currentColor;
    width: .85em;
    height: .85em;
    margin-left: .3em;
    display: inline-block;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M10 6H6a2 2 0 00-2 2v10a2 2 0 002 2h10a2 2 0 002-2v-4M14 4h6m0 0v6m0-6L10 14'%3E%3C/path%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M10 6H6a2 2 0 00-2 2v10a2 2 0 002 2h10a2 2 0 002-2v-4M14 4h6m0 0v6m0-6L10 14'%3E%3C/path%3E%3C/svg%3E");
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
  }

  color-scheme-switcher {
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
         user-select: none;
    -webkit-tap-highlight-color: transparent;
    justify-content: center;
    align-items: center;
    display: inline-flex;
  }

  color-scheme-switcher:hover {
    opacity: .8;
  }

  color-scheme-switcher:focus-visible {
    outline: 2px solid var(--accent-color);
    outline-offset: 2px;
    border-radius: 4px;
  }

  accordion-component {
    width: 100%;
    display: block;
  }

  accordion-component::part(target):focus-visible {
    outline: 2px solid var(--accent-color);
    outline-offset: 2px;
  }

  accordion-component[open]::part(content) {
    margin-bottom: .5rem;
  }

  accordion-component[open] [data-icon="chevron_down"] {
    transform: scaleY(-1);
  }

  .pswp {
    --pswp-bg: #000;
    --pswp-placeholder-bg: #222;
    --pswp-root-z-index: 100000;
    --pswp-preloader-color: #4f4f4f66;
    --pswp-preloader-color-secondary: #ffffffe6;
    --pswp-icon-color: #fff;
    --pswp-icon-color-secondary: #4f4f4f;
    --pswp-icon-stroke-color: #4f4f4f;
    --pswp-icon-stroke-width: 2px;
    --pswp-error-text-color: var(--pswp-icon-color);
    width: 100%;
    height: 100%;
    z-index: var(--pswp-root-z-index);
    touch-action: none;
    opacity: .003;
    contain: layout style size;
    -webkit-tap-highlight-color: #0000;
    outline: 0;
    display: none;
    position: fixed;
    top: 0;
    left: 0;
  }

  .pswp:focus {
    outline: 0;
  }

  .pswp * {
    box-sizing: border-box;
  }

  .pswp img {
    max-width: none;
  }

  .pswp--open {
    display: block;
  }

  .pswp, .pswp__bg {
    will-change: opacity;
    transform: translateZ(0);
  }

  .pswp__bg {
    opacity: .005;
    background: var(--pswp-bg);
  }

  .pswp, .pswp__scroll-wrap {
    overflow: hidden;
  }

  .pswp__scroll-wrap, .pswp__bg, .pswp__container, .pswp__item, .pswp__content, .pswp__img, .pswp__zoom-wrap {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
  }

  .pswp__img, .pswp__zoom-wrap {
    width: auto;
    height: auto;
  }

  .pswp--click-to-zoom.pswp--zoom-allowed .pswp__img {
    cursor: zoom-in;
  }

  .pswp--click-to-zoom.pswp--zoomed-in .pswp__img {
    cursor: move;
    cursor: grab;
  }

  .pswp--click-to-zoom.pswp--zoomed-in .pswp__img:active {
    cursor: grabbing;
  }

  .pswp--no-mouse-drag.pswp--zoomed-in .pswp__img, .pswp--no-mouse-drag.pswp--zoomed-in .pswp__img:active, .pswp__img {
    cursor: zoom-out;
  }

  .pswp__container, .pswp__img, .pswp__button, .pswp__counter {
    -webkit-user-select: none;
    -moz-user-select: none;
         user-select: none;
  }

  .pswp__item {
    z-index: 1;
    overflow: hidden;
  }

  .pswp__hidden {
    display: none !important;
  }

  .pswp__content {
    pointer-events: none;
  }

  .pswp__content > * {
    pointer-events: auto;
  }

  .pswp__error-msg-container {
    display: grid;
  }

  .pswp__error-msg {
    color: var(--pswp-error-text-color);
    margin: auto;
    font-size: 1em;
    line-height: 1;
  }

  .pswp .pswp__hide-on-close {
    opacity: .005;
    will-change: opacity;
    transition: opacity var(--pswp-transition-duration) cubic-bezier(.4, 0, .22, 1);
    z-index: 10;
    pointer-events: none;
  }

  .pswp--ui-visible .pswp__hide-on-close {
    opacity: 1;
    pointer-events: auto;
  }

  .pswp__button {
    cursor: pointer;
    width: 50px;
    height: 60px;
    box-shadow: none;
    opacity: .85;
    -webkit-appearance: none;
    -webkit-touch-callout: none;
    background: none;
    border: 0;
    margin: 0;
    padding: 0;
    display: block;
    position: relative;
    overflow: hidden;
  }

  .pswp__button:hover, .pswp__button:active, .pswp__button:focus {
    box-shadow: none;
    opacity: 1;
    background: none;
    border: 0;
    padding: 0;
    transition: none;
  }

  .pswp__button:disabled {
    opacity: .3;
    cursor: auto;
  }

  .pswp__icn {
    fill: var(--pswp-icon-color);
    color: var(--pswp-icon-color-secondary);
    pointer-events: none;
    width: 32px;
    height: 32px;
    position: absolute;
    top: 14px;
    left: 9px;
    overflow: hidden;
  }

  .pswp__icn-shadow {
    stroke: var(--pswp-icon-stroke-color);
    stroke-width: var(--pswp-icon-stroke-width);
    fill: none;
  }

  .pswp__icn:focus {
    outline: 0;
  }

  div.pswp__img--placeholder, .pswp__img--with-bg {
    background: var(--pswp-placeholder-bg);
  }

  .pswp__top-bar {
    z-index: 10;
    flex-direction: row;
    justify-content: flex-end;
    width: 100%;
    height: 60px;
    display: flex;
    position: absolute;
    top: 0;
    left: 0;
    pointer-events: none !important;
  }

  .pswp__top-bar > * {
    pointer-events: auto;
    will-change: opacity;
  }

  .pswp__button--close {
    margin-right: 6px;
  }

  .pswp__button--arrow {
    width: 75px;
    height: 100px;
    margin-top: -50px;
    position: absolute;
    top: 50%;
  }

  .pswp__button--arrow:disabled {
    cursor: default;
    display: none;
  }

  .pswp__button--arrow .pswp__icn {
    background: none;
    border-radius: 0;
    width: 60px;
    height: 60px;
    margin-top: -30px;
    top: 50%;
  }

  .pswp--one-slide .pswp__button--arrow {
    display: none;
  }

  .pswp--touch .pswp__button--arrow {
    visibility: hidden;
  }

  .pswp--has_mouse .pswp__button--arrow {
    visibility: visible;
  }

  .pswp__button--arrow--prev {
    left: 0;
    right: auto;
  }

  .pswp__button--arrow--next {
    right: 0;
  }

  .pswp__button--arrow--next .pswp__icn {
    left: auto;
    right: 14px;
    transform: scale(-1, 1);
  }

  .pswp__button--zoom {
    display: none;
  }

  .pswp--zoom-allowed .pswp__button--zoom {
    display: block;
  }

  .pswp--zoomed-in .pswp__zoom-icn-bar-v {
    display: none;
  }

  .pswp__preloader {
    width: 50px;
    height: 60px;
    margin-right: auto;
    position: relative;
    overflow: hidden;
  }

  .pswp__preloader .pswp__icn {
    opacity: 0;
    transition: opacity .2s linear;
    animation: .6s linear infinite pswp-clockwise;
  }

  .pswp__preloader--active .pswp__icn {
    opacity: .85;
  }

  @keyframes pswp-clockwise {
    0% {
      transform: rotate(0);
    }

    100% {
      transform: rotate(360deg);
    }
  }

  .pswp__counter {
    height: 30px;
    color: var(--pswp-icon-color);
    text-shadow: 1px 1px 3px var(--pswp-icon-color-secondary);
    opacity: .85;
    margin-top: 15px;
    margin-inline-start: 20px;
    font-size: 14px;
    line-height: 30px;
  }

  .pswp--one-slide .pswp__counter {
    display: none;
  }

  .pswp__button--arrow--next, .pswp__button--arrow--prev {
    justify-content: center;
    align-items: center;
    width: 4rem;
    height: 4rem;
    display: flex;
  }

  :is(.pswp__button--arrow--next, .pswp__button--arrow--prev) svg {
    display: none;
  }

  :is(.pswp__button--arrow--next, .pswp__button--arrow--prev):before {
    font-family: icon-font;
    font-size: 1.5rem;
    font-weight: 600;
  }

  .pswp__button--arrow--next:before {
    content: "arrow_right";
  }

  .pswp__button--arrow--prev:before {
    content: "arrow_left";
  }

  carousel-component {
    width: 100%;
    display: block;
    position: relative;
  }

  carousel-component * {
    -webkit-user-drag: none;
  }

  .carousel-container {
    background-color: inherit;
    width: 100%;
    position: relative;
  }

  .carousel-container:before {
    content: "";
    background-color: inherit;
    z-index: -1;
    -webkit-backdrop-filter: blur(2rem);
    backdrop-filter: blur(2rem);
    background: #00000040;
    position: absolute;
    inset: 0;
  }

  .carousel-container .carousel-content {
    scrollbar-width: none;
    -ms-overflow-style: none;
    width: 100%;
    display: flex;
    position: relative;
    overflow-x: auto;
    padding-inline-start: calc((100vw - var(--content-max-width)) / 2 + var(--content-padding-x)) !important;
  }

  .carousel-container .carousel-content::-webkit-scrollbar {
    display: none;
  }

  .carousel-container .carousel-content {
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
  }

  .carousel-container .carousel-content > * {
    scroll-snap-align: start;
  }

  .carousel-container .carousel-button {
    background-color: var(--bg-color-0);
    cursor: pointer;
    z-index: 10;
    cursor: pointer;
    border-radius: 100%;
    justify-content: center;
    align-items: center;
    width: 3rem;
    height: 3rem;
    transition: opacity .2s, transform .2s, background-color .2s;
    display: flex;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    box-shadow: 0 0 .5rem #0000001a;
  }

  .carousel-container .carousel-button.disabled, .carousel-container .carousel-button[disabled] {
    opacity: 0;
    pointer-events: none;
  }

  .carousel-container .carousel-button:hover {
    background-color: var(--bg-color-1);
  }

  .carousel-container .carousel-button[data-carousel-prev] {
    padding-left: .05rem;
    left: 0;
    transform: translateY(-50%)translateX(-50%);
  }

  .carousel-container .carousel-button[data-carousel-next] {
    padding-right: .05rem;
    right: 0;
    transform: translateY(-50%)translateX(50%);
  }

  @media (max-width: 640px) {
    .carousel-container .carousel-button {
      width: 2.5rem;
      height: 2.5rem;
    }

    .carousel-container .carousel-button[data-carousel-prev] {
      left: .5rem;
      transform: translateY(-50%);
    }

    .carousel-container .carousel-button[data-carousel-next] {
      right: .5rem;
      transform: translateY(-50%);
    }
  }

  .post-card {
    --heading-line-clamp: 2;
    --paragraph-line-clamp: 2;
    flex-direction: column;
    gap: .75rem;
    display: flex;
    position: relative;
  }

  .post-card figure {
    background-color: var(--bg-color-1);
    flex-shrink: 0;
    transition: all .5s cubic-bezier(.34, 1.56, .64, 1);
    overflow: hidden;
  }

  .post-card figure img {
    -o-object-fit: cover;
       object-fit: cover;
    width: 100%;
    height: 100%;
    transition: transform .3s ease-in-out;
  }

  .post-card figure figcaption {
    display: none !important;
  }

  .post-card .post-card-content {
    flex-direction: column;
    gap: .5rem;
    display: flex;
  }

  .post-card .post-card-content h3, .post-card .post-card-content .post-card-excerpt {
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
  }

  .post-card .post-card-content h3 {
    -webkit-line-clamp: var(--heading-line-clamp);
    line-clamp: var(--heading-line-clamp);
  }

  .post-card .post-card-content .post-card-excerpt {
    -webkit-line-clamp: var(--paragraph-line-clamp);
    line-clamp: var(--paragraph-line-clamp);
    color: var(--text-color-1);
    font-size: var(--font-size-s);
    opacity: .9;
  }

  .post-card time {
    color: var(--text-color-2);
  }

  .post-card:hover figure {
    transform: scale(1.015);
  }

  .post-card:hover figure img {
    transform: scale(1.05);
  }

  .post-card--row, .post-card--row-reverse {
    flex-direction: row;
    align-items: center;
    gap: 1.5rem;
  }

  :is(.post-card--row, .post-card--row-reverse) figure {
    aspect-ratio: 1;
    height: 100%;
  }

  .post-card--row-reverse {
    flex-direction: row-reverse;
  }

  .post-card--column, .post-card--column-reverse {
    flex-direction: column;
  }

  :is(.post-card--column, .post-card--column-reverse) figure {
    aspect-ratio: 1.6;
    width: 100%;
  }

  :is(.post-card--column, .post-card--column-reverse) .post-card-content {
    flex: 1;
  }

  .post-card--column-reverse {
    flex-direction: column-reverse;
  }

  .post-card--no-image .post-card-content {
    width: 100%;
  }

  .post-card--no-image.post-card--column, .post-card--no-image.post-card--column-reverse {
    background-color: var(--bg-color-1);
    padding: 1.5rem;
  }

  :is(.post-card--no-image.post-card--column, .post-card--no-image.post-card--column-reverse) .post-card-content {
    justify-content: center;
  }

  .red-text {
    color: var(--color-darker-red);
  }

  .post-content {
    max-width: var(--post-content-max-width);
    flex-direction: column;
    gap: 2rem;
    width: 100%;
    margin: auto;
    display: flex;
  }

  .post-content .post-body {
    width: 100%;
    line-height: var(--line-height-base) !important;
    font-size: 1.125rem !important;
  }

  .post-content .post-body:only-child {
    margin-bottom: 6rem;
  }

  .post-content .post-body p a {
    color: var(--accent-color);
    text-decoration: underline;
  }

  html {
    scroll-timeline: --page-scroll block;
  }

  scroll-indicator {
    z-index: 99;
    cursor: pointer;
    opacity: 0;
    transition: opacity .3s ease-in-out, transform .2s ease-in-out;
    display: none;
    position: fixed;
    bottom: 2rem;
    right: 2.5rem;
  }

  scroll-indicator:hover {
    transform: translateY(-2px);
  }

  @media (max-width: 640px) {
    scroll-indicator {
      bottom: 1rem;
      right: 1rem;
    }
  }

  .scroll-indicator {
    background: var(--bg-color-0);
    box-sizing: content-box;
    border-radius: 50%;
    justify-content: center;
    align-items: center;
    width: 3rem;
    height: 3rem;
    padding: 5px;
    font-size: 1.25rem;
    transition: background-color .2s ease-in-out, box-shadow .2s ease-in-out;
    display: flex;
    position: relative;
    box-shadow: 0 2px 8px #0000001a;
  }

  .scroll-indicator:hover {
    background: var(--bg-color-1);
    box-shadow: 0 3px 10px #00000026;
  }

  @media (max-width: 640px) {
    .scroll-indicator {
      width: 2.5rem;
      height: 2.5rem;
    }
  }

  .scroll-indicator svg {
    width: 100%;
    height: 100%;
    position: absolute;
    inset: 0;
    overflow: visible;
    transform: rotate(-90deg);
  }

  .scroll-indicator svg circle {
    cx: 50%;
    cy: 50%;
    r: 47%;
    stroke-dasharray: 295;
    stroke-linecap: round;
    stroke: var(--text-color-0);
    fill: none;
    stroke-width: 3px;
    transition: stroke-width .3s ease-in-out;
  }

  .scroll-indicator svg:hover circle {
    stroke-width: 6px;
  }

  .social-icons {
    flex-wrap: wrap;
    gap: 1rem;
    display: flex;
  }

  .social-icon {
    color: var(--text-color-0);
    justify-content: center;
    align-items: center;
    font-size: 1.25em;
    transition: all .15s;
    display: flex;
  }

  .social-icon:hover {
    color: var(--text-color-1);
    transform: scale(1.1);
  }
}

@layer utilities {
  .visible {
    visibility: visible;
  }

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

  .\!static {
    position: static !important;
  }

  .absolute {
    position: absolute;
  }

  .relative {
    position: relative;
  }

  .static {
    position: static;
  }

  .sticky {
    position: sticky;
  }

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

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

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

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

  .left-1\/2 {
    left: 50%;
  }

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

  .order-1 {
    order: 1;
  }

  .order-2 {
    order: 2;
  }

  .order-3 {
    order: 3;
  }

  .col-span-1 {
    grid-column: span 1 / span 1;
  }

  .col-span-3 {
    grid-column: span 3 / span 3;
  }

  .row-span-3 {
    grid-row: span 3 / span 3;
  }

  .row-span-4 {
    grid-row: span 4 / span 4;
  }

  .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;
    }
  }

  .-mx-8 {
    margin-inline: calc(var(--spacing) * -8);
  }

  .mx-auto {
    margin-inline: auto;
  }

  .my-8 {
    margin-block: calc(var(--spacing) * 8);
  }

  .my-32 {
    margin-block: calc(var(--spacing) * 32);
  }

  .prose {
    color: var(--tw-prose-body);
  }

  .prose :where(p):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 1.25em;
    margin-bottom: 1.25em;
  }

  .prose :where([class~="lead"]):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-lead);
    margin-top: 1.2em;
    margin-bottom: 1.2em;
    font-size: 1.25em;
    line-height: 1.6;
  }

  .prose :where(a):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-links);
    font-weight: 500;
    text-decoration: underline;
  }

  .prose :where(strong):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-bold);
    font-weight: 600;
  }

  .prose :where(a strong):not(:where([class~="not-prose"], [class~="not-prose"] *)), .prose :where(blockquote strong):not(:where([class~="not-prose"], [class~="not-prose"] *)), .prose :where(thead th strong):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: inherit;
  }

  .prose :where(ol):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 1.25em;
    margin-bottom: 1.25em;
    padding-inline-start: 1.625em;
    list-style-type: decimal;
  }

  .prose :where(ol[type="A"]):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    list-style-type: upper-alpha;
  }

  .prose :where(ol[type="a"]):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    list-style-type: lower-alpha;
  }

  .prose :where(ol[type="A" s]):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    list-style-type: upper-alpha;
  }

  .prose :where(ol[type="a" s]):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    list-style-type: lower-alpha;
  }

  .prose :where(ol[type="I"]):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    list-style-type: upper-roman;
  }

  .prose :where(ol[type="i"]):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    list-style-type: lower-roman;
  }

  .prose :where(ol[type="I" s]):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    list-style-type: upper-roman;
  }

  .prose :where(ol[type="i" s]):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    list-style-type: lower-roman;
  }

  .prose :where(ol[type="1"]):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    list-style-type: decimal;
  }

  .prose :where(ul):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 1.25em;
    margin-bottom: 1.25em;
    padding-inline-start: 1.625em;
    list-style-type: disc;
  }

  .prose :where(ol > li):not(:where([class~="not-prose"], [class~="not-prose"] *))::marker {
    color: var(--tw-prose-counters);
    font-weight: 400;
  }

  .prose :where(ul > li):not(:where([class~="not-prose"], [class~="not-prose"] *))::marker {
    color: var(--tw-prose-bullets);
  }

  .prose :where(dt):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-headings);
    margin-top: 1.25em;
    font-weight: 600;
  }

  .prose :where(hr):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    border-color: var(--tw-prose-hr);
    border-top-width: 1px;
    margin-top: 3em;
    margin-bottom: 3em;
  }

  .prose :where(blockquote):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-quotes);
    border-inline-start-width: .25rem;
    border-inline-start-color: var(--tw-prose-quote-borders);
    quotes: "“""”""‘""’";
    margin-top: 1.6em;
    margin-bottom: 1.6em;
    padding-inline-start: 1em;
    font-style: italic;
    font-weight: 500;
  }

  .prose :where(blockquote p:first-of-type):not(:where([class~="not-prose"], [class~="not-prose"] *)):before {
    content: open-quote;
  }

  .prose :where(blockquote p:last-of-type):not(:where([class~="not-prose"], [class~="not-prose"] *)):after {
    content: close-quote;
  }

  .prose :where(h1):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-headings);
    margin-top: 0;
    margin-bottom: .888889em;
    font-size: 2.25em;
    font-weight: 800;
    line-height: 1.11111;
  }

  .prose :where(h1 strong):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: inherit;
    font-weight: 900;
  }

  .prose :where(h2):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-headings);
    margin-top: 2em;
    margin-bottom: 1em;
    font-size: 1.5em;
    font-weight: 700;
    line-height: 1.33333;
  }

  .prose :where(h2 strong):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: inherit;
    font-weight: 800;
  }

  .prose :where(h3):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-headings);
    margin-top: 1.6em;
    margin-bottom: .6em;
    font-size: 1.25em;
    font-weight: 600;
    line-height: 1.6;
  }

  .prose :where(h3 strong):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: inherit;
    font-weight: 700;
  }

  .prose :where(h4):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-headings);
    margin-top: 1.5em;
    margin-bottom: .5em;
    font-weight: 600;
    line-height: 1.5;
  }

  .prose :where(h4 strong):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: inherit;
    font-weight: 700;
  }

  .prose :where(img):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 2em;
    margin-bottom: 2em;
  }

  .prose :where(picture):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 2em;
    margin-bottom: 2em;
    display: block;
  }

  .prose :where(video):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 2em;
    margin-bottom: 2em;
  }

  .prose :where(kbd):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-kbd);
    box-shadow: 0 0 0 1px rgb(var(--tw-prose-kbd-shadows) / 10%), 0 3px 0 rgb(var(--tw-prose-kbd-shadows) / 10%);
    padding-top: .1875em;
    padding-inline-end: .375em;
    padding-bottom: .1875em;
    border-radius: .3125rem;
    padding-inline-start: .375em;
    font-family: inherit;
    font-size: .875em;
    font-weight: 500;
  }

  .prose :where(code):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-code);
    font-size: .875em;
    font-weight: 600;
  }

  .prose :where(code):not(:where([class~="not-prose"], [class~="not-prose"] *)):before, .prose :where(code):not(:where([class~="not-prose"], [class~="not-prose"] *)):after {
    content: "`";
  }

  .prose :where(a code):not(:where([class~="not-prose"], [class~="not-prose"] *)), .prose :where(h1 code):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: inherit;
  }

  .prose :where(h2 code):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: inherit;
    font-size: .875em;
  }

  .prose :where(h3 code):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: inherit;
    font-size: .9em;
  }

  .prose :where(h4 code):not(:where([class~="not-prose"], [class~="not-prose"] *)), .prose :where(blockquote code):not(:where([class~="not-prose"], [class~="not-prose"] *)), .prose :where(thead th code):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: inherit;
  }

  .prose :where(pre):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-pre-code);
    background-color: var(--tw-prose-pre-bg);
    padding-top: .857143em;
    padding-inline-end: 1.14286em;
    padding-bottom: .857143em;
    border-radius: .375rem;
    margin-top: 1.71429em;
    margin-bottom: 1.71429em;
    padding-inline-start: 1.14286em;
    font-size: .875em;
    font-weight: 400;
    line-height: 1.71429;
    overflow-x: auto;
  }

  .prose :where(pre code):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    font-weight: inherit;
    color: inherit;
    font-size: inherit;
    font-family: inherit;
    line-height: inherit;
    background-color: #0000;
    border-width: 0;
    border-radius: 0;
    padding: 0;
  }

  .prose :where(pre code):not(:where([class~="not-prose"], [class~="not-prose"] *)):before, .prose :where(pre code):not(:where([class~="not-prose"], [class~="not-prose"] *)):after {
    content: none;
  }

  .prose :where(table):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    table-layout: auto;
    width: 100%;
    margin-top: 2em;
    margin-bottom: 2em;
    font-size: .875em;
    line-height: 1.71429;
  }

  .prose :where(thead):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    border-bottom-width: 1px;
    border-bottom-color: var(--tw-prose-th-borders);
  }

  .prose :where(thead th):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-headings);
    vertical-align: bottom;
    padding-inline-end: .571429em;
    padding-bottom: .571429em;
    padding-inline-start: .571429em;
    font-weight: 600;
  }

  .prose :where(tbody tr):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    border-bottom-width: 1px;
    border-bottom-color: var(--tw-prose-td-borders);
  }

  .prose :where(tbody tr:last-child):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    border-bottom-width: 0;
  }

  .prose :where(tbody td):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    vertical-align: baseline;
  }

  .prose :where(tfoot):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    border-top-width: 1px;
    border-top-color: var(--tw-prose-th-borders);
  }

  .prose :where(tfoot td):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    vertical-align: top;
  }

  .prose :where(th, td):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    text-align: start;
  }

  .prose :where(figure > *):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 0;
    margin-bottom: 0;
  }

  .prose :where(figcaption):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    color: var(--tw-prose-captions);
    margin-top: .857143em;
    font-size: .875em;
    line-height: 1.42857;
  }

  .prose {
    --tw-prose-body: var(--text-color-0);
    --tw-prose-headings: var(--text-color-0);
    --tw-prose-lead: var(--text-color-1);
    --tw-prose-links: var(--accent-color);
    --tw-prose-bold: var(--text-color-0);
    --tw-prose-counters: var(--text-color-1);
    --tw-prose-bullets: var(--text-color-1);
    --tw-prose-hr: var(--border-color-0);
    --tw-prose-quotes: var(--text-color-0);
    --tw-prose-quote-borders: var(--border-color-0);
    --tw-prose-captions: var(--text-muted);
    --tw-prose-kbd: oklch(21% .034 264.665);
    --tw-prose-kbd-shadows: NaN NaN NaN;
    --tw-prose-code: var(--text-color-0);
    --tw-prose-pre-code: var(--text-color-0);
    --tw-prose-pre-bg: var(--pre-background-color);
    --tw-prose-th-borders: var(--border-color-0);
    --tw-prose-td-borders: var(--border-color-0);
    --tw-prose-invert-body: oklch(87.2% .01 258.338);
    --tw-prose-invert-headings: #fff;
    --tw-prose-invert-lead: oklch(70.7% .022 261.325);
    --tw-prose-invert-links: #fff;
    --tw-prose-invert-bold: #fff;
    --tw-prose-invert-counters: oklch(70.7% .022 261.325);
    --tw-prose-invert-bullets: oklch(44.6% .03 256.802);
    --tw-prose-invert-hr: oklch(37.3% .034 259.733);
    --tw-prose-invert-quotes: oklch(96.7% .003 264.542);
    --tw-prose-invert-quote-borders: oklch(37.3% .034 259.733);
    --tw-prose-invert-captions: oklch(70.7% .022 261.325);
    --tw-prose-invert-kbd: #fff;
    --tw-prose-invert-kbd-shadows: 255 255 255;
    --tw-prose-invert-code: #fff;
    --tw-prose-invert-pre-code: oklch(87.2% .01 258.338);
    --tw-prose-invert-pre-bg: #00000080;
    --tw-prose-invert-th-borders: oklch(44.6% .03 256.802);
    --tw-prose-invert-td-borders: oklch(37.3% .034 259.733);
    font-size: 1rem;
    line-height: 1.75;
  }

  .prose :where(picture > img):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 0;
    margin-bottom: 0;
  }

  .prose :where(li):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: .5em;
    margin-bottom: .5em;
  }

  .prose :where(ol > li):not(:where([class~="not-prose"], [class~="not-prose"] *)), .prose :where(ul > li):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    padding-inline-start: .375em;
  }

  .prose :where(.prose > ul > li p):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: .75em;
    margin-bottom: .75em;
  }

  .prose :where(.prose > ul > li > p:first-child):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 1.25em;
  }

  .prose :where(.prose > ul > li > p:last-child):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-bottom: 1.25em;
  }

  .prose :where(.prose > ol > li > p:first-child):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 1.25em;
  }

  .prose :where(.prose > ol > li > p:last-child):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-bottom: 1.25em;
  }

  .prose :where(ul ul, ul ol, ol ul, ol ol):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: .75em;
    margin-bottom: .75em;
  }

  .prose :where(dl):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 1.25em;
    margin-bottom: 1.25em;
  }

  .prose :where(dd):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: .5em;
    padding-inline-start: 1.625em;
  }

  .prose :where(hr + *):not(:where([class~="not-prose"], [class~="not-prose"] *)), .prose :where(h2 + *):not(:where([class~="not-prose"], [class~="not-prose"] *)), .prose :where(h3 + *):not(:where([class~="not-prose"], [class~="not-prose"] *)), .prose :where(h4 + *):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 0;
  }

  .prose :where(thead th:first-child):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    padding-inline-start: 0;
  }

  .prose :where(thead th:last-child):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    padding-inline-end: 0;
  }

  .prose :where(tbody td, tfoot td):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    padding-top: .571429em;
    padding-inline-end: .571429em;
    padding-bottom: .571429em;
    padding-inline-start: .571429em;
  }

  .prose :where(tbody td:first-child, tfoot td:first-child):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    padding-inline-start: 0;
  }

  .prose :where(tbody td:last-child, tfoot td:last-child):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    padding-inline-end: 0;
  }

  .prose :where(figure):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 2em;
    margin-bottom: 2em;
  }

  .prose :where(.prose > :first-child):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-top: 0;
  }

  .prose :where(.prose > :last-child):not(:where([class~="not-prose"], [class~="not-prose"] *)) {
    margin-bottom: 0;
  }

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

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

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

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

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

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

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

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

  .mt-auto {
    margin-top: auto;
  }

  .-mr-4 {
    margin-right: calc(var(--spacing) * -4);
  }

  .mr-4 {
    margin-right: calc(var(--spacing) * 4);
  }

  .mr-8 {
    margin-right: calc(var(--spacing) * 8);
  }

  .\!mb-1 {
    margin-bottom: calc(var(--spacing) * 1) !important;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

  .\!line-clamp-4 {
    -webkit-line-clamp: 4 !important;
    -webkit-box-orient: vertical !important;
    display: -webkit-box !important;
    overflow: hidden !important;
  }

  .line-clamp-2 {
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
  }

  .\!hidden {
    display: none !important;
  }

  .block {
    display: block;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

  .inline {
    display: inline;
  }

  .\!aspect-\[1\.4\] {
    aspect-ratio: 1.4 !important;
  }

  .\!aspect-\[1\.6\] {
    aspect-ratio: 1.6 !important;
  }

  .\!aspect-\[1\.8\] {
    aspect-ratio: 1.8 !important;
  }

  .\!aspect-\[1\.75\] {
    aspect-ratio: 1.75 !important;
  }

  .\!aspect-auto {
    aspect-ratio: auto !important;
  }

  .\!aspect-square {
    aspect-ratio: 1 !important;
  }

  .aspect-\[0\.667\] {
    aspect-ratio: .667;
  }

  .aspect-\[calc\(1\/1\.3\)\] {
    aspect-ratio: .769231;
  }

  .aspect-square {
    aspect-ratio: 1;
  }

  .\!h-28 {
    height: calc(var(--spacing) * 28) !important;
  }

  .\!h-32 {
    height: calc(var(--spacing) * 32) !important;
  }

  .\!h-auto {
    height: auto !important;
  }

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

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

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

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

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

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

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

  .h-\[50vh\] {
    height: 50vh;
  }

  .h-\[70vh\] {
    height: 70vh;
  }

  .h-\[90vh\] {
    height: 90vh;
  }

  .h-\[calc\(100dvh-175px\)\] {
    height: calc(100dvh - 175px);
  }

  .h-\[var\(--screen-height-without-header\)\] {
    height: var(--screen-height-without-header);
  }

  .h-auto {
    height: auto;
  }

  .h-fit {
    height: -moz-fit-content;
    height: fit-content;
  }

  .h-full {
    height: 100%;
  }

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

  .max-h-\[30vh\] {
    max-height: 30vh;
  }

  .\!w-32 {
    width: calc(var(--spacing) * 32) !important;
  }

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

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

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

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

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

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

  .w-auto {
    width: auto;
  }

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

  .w-full {
    width: 100%;
  }

  .w-screen {
    width: 100vw;
  }

  .max-w-3xl {
    max-width: var(--container-3xl);
  }

  .max-w-6xl {
    max-width: var(--container-6xl);
  }

  .max-w-7xl {
    max-width: var(--container-7xl);
  }

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

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

  .max-w-\[70rem\] {
    max-width: 70rem;
  }

  .max-w-\[400px\] {
    max-width: 400px;
  }

  .max-w-\[var\(--post-content-max-width\)\] {
    max-width: var(--post-content-max-width);
  }

  .max-w-full {
    max-width: 100%;
  }

  .max-w-lg {
    max-width: var(--container-lg);
  }

  .max-w-screen {
    max-width: 100vw;
  }

  .min-w-\[300px\] {
    min-width: 300px;
  }

  .min-w-\[320px\] {
    min-width: 320px;
  }

  .\!flex-1 {
    flex: 1 !important;
  }

  .flex-1 {
    flex: 1;
  }

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

  .-translate-x-1\/2 {
    --tw-translate-x: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .translate-y-\[1px\] {
    --tw-translate-y: 1px;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .scale-\[85\%\] {
    scale: 85%;
  }

  .transform {
    transform: var(--tw-rotate-x, ) var(--tw-rotate-y, ) var(--tw-rotate-z, ) var(--tw-skew-x, ) var(--tw-skew-y, );
  }

  .cursor-pointer {
    cursor: pointer;
  }

  .touch-manipulation {
    touch-action: manipulation;
  }

  .resize {
    resize: both;
  }

  .snap-x {
    scroll-snap-type: x var(--tw-scroll-snap-strictness);
  }

  .snap-mandatory {
    --tw-scroll-snap-strictness: mandatory;
  }

  .snap-center {
    scroll-snap-align: center;
  }

  .snap-start {
    scroll-snap-align: start;
  }

  .grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .grid-rows-4 {
    grid-template-rows: repeat(4, minmax(0, 1fr));
  }

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

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

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

  .\!items-start {
    align-items: flex-start !important;
  }

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

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

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

  .\!justify-start {
    justify-content: flex-start !important;
  }

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

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

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

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

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

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

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

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

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

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

  .gap-x-8 {
    -moz-column-gap: calc(var(--spacing) * 8);
         column-gap: calc(var(--spacing) * 8);
  }

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

  .gap-y-4 {
    row-gap: calc(var(--spacing) * 4);
  }

  .gap-y-8 {
    row-gap: calc(var(--spacing) * 8);
  }

  .gap-y-16 {
    row-gap: calc(var(--spacing) * 16);
  }

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

  .overflow-hidden {
    overflow: hidden;
  }

  .overflow-x-hidden {
    overflow-x: hidden;
  }

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

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

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

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

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

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

  .border-0 {
    border-color: var(--bg-color-0);
  }

  .border-b0 {
    border-color: var(--border-color-0);
  }

  .\!bg-transparent {
    background-color: #0000 !important;
  }

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

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

  .bg-cover {
    background-size: cover;
  }

  .bg-center {
    background-position: center;
  }

  .\!object-contain {
    -o-object-fit: contain !important;
       object-fit: contain !important;
  }

  .\!object-scale-down {
    -o-object-fit: scale-down !important;
       object-fit: scale-down !important;
  }

  .object-contain {
    -o-object-fit: contain;
       object-fit: contain;
  }

  .object-cover {
    -o-object-fit: cover;
       object-fit: cover;
  }

  .\!object-left {
    -o-object-position: left !important;
       object-position: left !important;
  }

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

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

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

  .\!px-4 {
    padding-inline: calc(var(--spacing) * 4) !important;
  }

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

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

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

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

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

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

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

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

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

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

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

  .pt-8 {
    padding-top: calc(var(--spacing) * 8);
  }

  .pt-12 {
    padding-top: calc(var(--spacing) * 12);
  }

  .pt-24 {
    padding-top: calc(var(--spacing) * 24);
  }

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

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

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

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

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

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

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

  .pl-\[var\(--content-padding-x\)\] {
    padding-left: var(--content-padding-x);
  }

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

  .align-bottom {
    vertical-align: bottom;
  }

  .\!text-4xl {
    font-size: var(--text-4xl) !important;
    line-height: var(--tw-leading, var(--text-4xl--line-height)) !important;
  }

  .\!text-5xl {
    font-size: var(--text-5xl) !important;
    line-height: var(--tw-leading, var(--text-5xl--line-height)) !important;
  }

  .\!text-9xl {
    font-size: var(--text-9xl) !important;
    line-height: var(--tw-leading, var(--text-9xl--line-height)) !important;
  }

  .\!text-lg {
    font-size: var(--text-lg) !important;
    line-height: var(--tw-leading, var(--text-lg--line-height)) !important;
  }

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

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

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

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

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

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

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

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

  .\!text-h1 {
    font-size: var(--font-size-h1) !important;
  }

  .\!text-h4 {
    font-size: var(--font-size-h4) !important;
  }

  .\!text-h5 {
    font-size: var(--font-size-h5) !important;
  }

  .\!text-h6 {
    font-size: var(--font-size-h6) !important;
  }

  .text-h1 {
    font-size: var(--font-size-h1);
  }

  .text-h4 {
    font-size: var(--font-size-h4);
  }

  .text-h5 {
    font-size: var(--font-size-h5);
  }

  .leading-1 {
    --tw-leading: calc(var(--spacing) * 1);
    line-height: calc(var(--spacing) * 1);
  }

  .leading-\[1\.15\] {
    --tw-leading: 1.15;
    line-height: 1.15;
  }

  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }

  .leading-tight {
    --tw-leading: var(--leading-tight);
    line-height: var(--leading-tight);
  }

  .\!font-bold {
    --tw-font-weight: var(--font-weight-bold) !important;
    font-weight: var(--font-weight-bold) !important;
  }

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

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

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

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

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

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

  .text-balance {
    text-wrap: balance;
  }

  .text-nowrap {
    text-wrap: nowrap;
  }

  .break-all {
    word-break: break-all;
  }

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

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

  .text-red-500 {
    color: var(--color-red-500);
  }

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

  .text-white\/90 {
    color: #ffffffe6;
  }

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

  .lowercase {
    text-transform: lowercase;
  }

  .uppercase {
    text-transform: uppercase;
  }

  .underline {
    text-decoration-line: underline;
  }

  .underline-offset-2 {
    text-underline-offset: 2px;
  }

  .opacity-0 {
    opacity: 0;
  }

  .opacity-30 {
    opacity: .3;
  }

  .opacity-50 {
    opacity: .5;
  }

  .opacity-60 {
    opacity: .6;
  }

  .opacity-70 {
    opacity: .7;
  }

  .opacity-80 {
    opacity: .8;
  }

  .opacity-90 {
    opacity: .9;
  }

  .opacity-100 {
    opacity: 1;
  }

  .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-xl {
    --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, #0000001a), 0 8px 10px -6px 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);
  }

  .outline-white {
    outline-color: var(--color-white);
  }

  .blur {
    --tw-blur: blur(8px);
    filter: var(--tw-blur, ) var(--tw-brightness, ) var(--tw-contrast, ) var(--tw-grayscale, ) var(--tw-hue-rotate, ) var(--tw-invert, ) var(--tw-saturate, ) var(--tw-sepia, ) var(--tw-drop-shadow, );
  }

  .filter {
    filter: var(--tw-blur, ) var(--tw-brightness, ) var(--tw-contrast, ) var(--tw-grayscale, ) var(--tw-hue-rotate, ) var(--tw-invert, ) var(--tw-saturate, ) var(--tw-sepia, ) var(--tw-drop-shadow, );
  }

  .backdrop-filter {
    -webkit-backdrop-filter: var(--tw-backdrop-blur, ) var(--tw-backdrop-brightness, ) var(--tw-backdrop-contrast, ) var(--tw-backdrop-grayscale, ) var(--tw-backdrop-hue-rotate, ) var(--tw-backdrop-invert, ) var(--tw-backdrop-opacity, ) var(--tw-backdrop-saturate, ) var(--tw-backdrop-sepia, );
    backdrop-filter: var(--tw-backdrop-blur, ) var(--tw-backdrop-brightness, ) var(--tw-backdrop-contrast, ) var(--tw-backdrop-grayscale, ) var(--tw-backdrop-hue-rotate, ) var(--tw-backdrop-invert, ) var(--tw-backdrop-opacity, ) var(--tw-backdrop-saturate, ) var(--tw-backdrop-sepia, );
  }

  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, visibility, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

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

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

  .transition-transform {
    transition-property: transform, translate, scale, rotate;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .delay-400 {
    transition-delay: .4s;
  }

  .duration-200 {
    --tw-duration: .2s;
    transition-duration: .2s;
  }

  .duration-300 {
    --tw-duration: .3s;
    transition-duration: .3s;
  }

  .duration-400 {
    --tw-duration: .4s;
    transition-duration: .4s;
  }

  .ease-in-out {
    --tw-ease: var(--ease-in-out);
    transition-timing-function: var(--ease-in-out);
  }

  .outline-solid {
    --tw-outline-style: solid;
    outline-style: solid;
  }

  @media (hover: hover) {
    .group-hover\:translate-x-1:is(:where(.group):hover *) {
      --tw-translate-x: calc(var(--spacing) * 1);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }

    .group-hover\:scale-105:is(:where(.group):hover *) {
      --tw-scale-x: 105%;
      --tw-scale-y: 105%;
      --tw-scale-z: 105%;
      scale: var(--tw-scale-x) var(--tw-scale-y);
    }

    .group-hover\:opacity-40:is(:where(.group):hover *) {
      opacity: .4;
    }
  }

  .last\:mr-16:last-child {
    margin-right: calc(var(--spacing) * 16);
  }

  @media (hover: hover) {
    .hover\:-translate-y-1:hover {
      --tw-translate-y: calc(var(--spacing) * -1);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }

    .hover\:scale-\[90\%\]:hover {
      scale: 90%;
    }

    .hover\:underline:hover {
      text-decoration-line: underline;
    }

    .hover\:opacity-70:hover {
      opacity: .7;
    }

    .hover\:shadow-xl:hover {
      --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, #0000001a), 0 8px 10px -6px 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);
    }

    .hover\:outline-solid:hover {
      --tw-outline-style: solid;
      outline-style: solid;
    }
  }

  .nth-3\:border-t:nth-child(3) {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }

  .nth-3\:pt-4:nth-child(3) {
    padding-top: calc(var(--spacing) * 4);
  }

  .nth-4\:border-t:nth-child(4) {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }

  .nth-4\:pt-4:nth-child(4) {
    padding-top: calc(var(--spacing) * 4);
  }

  .nth-\[n\+5\]\:hidden:nth-child(n+5) {
    display: none;
  }

  .nth-last-1\:border-none:last-child, .nth-last-2\:border-none:nth-last-child(2), .nth-last-3\:border-none:nth-last-child(3) {
    --tw-border-style: none;
    border-style: none;
  }

  @media (min-width: 40rem) {
    .sm\:max-h-full {
      max-height: 100%;
    }

    .sm\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:order-1 {
      order: 1;
    }

    .md\:order-2 {
      order: 2;
    }

    .md\:col-span-1 {
      grid-column: span 1 / span 1;
    }

    .md\:col-span-2 {
      grid-column: span 2 / span 2;
    }

    .md\:col-span-3 {
      grid-column: span 3 / span 3;
    }

    .md\:mx-auto {
      margin-inline: auto;
    }

    .md\:mt-0 {
      margin-top: calc(var(--spacing) * 0);
    }

    .md\:mt-32 {
      margin-top: calc(var(--spacing) * 32);
    }

    .md\:flex {
      display: flex;
    }

    .md\:grid {
      display: grid;
    }

    .md\:hidden {
      display: none;
    }

    .md\:w-fit {
      width: -moz-fit-content;
      width: fit-content;
    }

    .md\:max-w-xl {
      max-width: var(--container-xl);
    }

    .md\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .md\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .md\:grid-cols-\[200px_1fr_200px\] {
      grid-template-columns: 200px 1fr 200px;
    }

    .md\:flex-nowrap {
      flex-wrap: nowrap;
    }

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

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

    .md\:justify-items-center {
      justify-items: center;
    }

    .md\:gap-y-2 {
      row-gap: calc(var(--spacing) * 2);
    }

    .md\:border-r {
      border-right-style: var(--tw-border-style);
      border-right-width: 1px;
    }

    .md\:border-l {
      border-left-style: var(--tw-border-style);
      border-left-width: 1px;
    }

    .md\:border-0 {
      border-color: var(--bg-color-0);
    }

    .md\:border-b0 {
      border-color: var(--border-color-0);
    }

    .md\:border-t-0 {
      border-top-color: var(--bg-color-0);
    }

    .md\:border-b-0 {
      border-bottom-color: var(--bg-color-0);
    }

    .md\:p-16 {
      padding: calc(var(--spacing) * 16);
    }

    .md\:px-0 {
      padding-inline: calc(var(--spacing) * 0);
    }

    .md\:pt-0 {
      padding-top: calc(var(--spacing) * 0);
    }

    .md\:\!pr-0 {
      padding-right: calc(var(--spacing) * 0) !important;
    }

    .md\:pr-0 {
      padding-right: calc(var(--spacing) * 0);
    }

    .md\:pr-8 {
      padding-right: calc(var(--spacing) * 8);
    }

    .md\:pl-8 {
      padding-left: calc(var(--spacing) * 8);
    }

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

  @media (min-width: 64rem) {
    .lg\:ml-auto {
      margin-left: auto;
    }

    .lg\:flex {
      display: flex;
    }

    .lg\:hidden {
      display: none;
    }

    .lg\:aspect-square {
      aspect-ratio: 1;
    }

    .lg\:max-h-full {
      max-height: 100%;
    }

    .lg\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .lg\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .lg\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .lg\:flex-row {
      flex-direction: row;
    }

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

    .lg\:gap-8 {
      gap: calc(var(--spacing) * 8);
    }

    .lg\:self-end {
      align-self: flex-end;
    }

    .lg\:\!text-2xl {
      font-size: var(--text-2xl) !important;
      line-height: var(--tw-leading, var(--text-2xl--line-height)) !important;
    }

    .lg\:nth-\[n\+5\]\:flex:nth-child(n+5) {
      display: flex;
    }
  }

  @media (min-width: 80rem) {
    .xl\:pl-0 {
      padding-left: calc(var(--spacing) * 0);
    }
  }

  @starting-style {
    .starting\:opacity-0 {
      opacity: 0;
    }
  }
}

:root {
  --color-bright-red: #c30e0e;
  --color-darker-red: #9d0c0c;
  --rem-size: clamp(14px, 1vmax, 16px);
  --font-family-heading: inherit;
  --font-family-body: inherit;
  --font-family-monospace: "Fira Code", monospace;
  --font-size-h1: 2.25rem;
  --font-size-h2: 1.75rem;
  --font-size-h3: 1.375rem;
  --font-size-h4: 1.25rem;
  --font-size-h5: 1.125rem;
  --font-size-h6: 1rem;
  --font-size-base: 1rem;
  --font-size-s: .9rem;
  --font-size-xs: .8rem;
  --font-weight-heading: 600;
  --font-weight-body: 400;
  --font-weight-monospace: 400;
  --letter-spacing-heading: -.02em;
  --letter-spacing-body: 0;
  --letter-spacing-monospace: 0;
  --line-height-h1: 1.05;
  --line-height-h2: 1.15;
  --line-height-h3: 1.25;
  --line-height-h4: 1.33;
  --line-height-h5: 1.33;
  --line-height-h6: 1.42;
  --line-height-base: 1.5;
  --border-radius-0: 0;
  --border-radius-1: 0;
  --border-radius-2: 0;
  --bg-color-0: #fff;
  --bg-color-1: #f2f4f6;
  --border-color-0: #00000013;
  --text-color-0: #111;
  --text-color-1: #4b5563;
  --text-color-2: #9ca3af;
  --text-muted: #6b7280;
  --site-logo-height: 2.5rem;
  --site-header-height: 9rem;
  --screen-height-without-header: calc(100dvh - var(--site-header-height));
  --content-max-width: 100rem;
  --content-padding-x: 4rem;
  --content-grid-gap-x: 2rem;
  --content-grid-gap-y: 4rem;
  --post-content-max-width: 52rem;
  --tag-color: var(--accent-color);
  --button-padding: .5em 1em;
  --button-height: 2.5em;
  --button-border-radius: var(--border-radius-1);
  --button-border: var(--accent-color);
  --button-background-color: var(--accent-color);
  --button-secondary-color: var(--text-color-0);
  --button-secondary-background-color: var(--bg-color-1);
  --button-secondary-border: 1px solid var(--border-color-0);
  --input-font-size: 1rem;
  --input-font-size-md: .875rem;
  --input-padding: .5em .75em;
  --input-height: 2.5em;
  --input-border-radius: var(--border-radius-1);
  --input-background-color: var(--bg-color-0);
  --input-color: var(--text-color);
  --input-border-color: var(--border-color-0);
  --input-placeholder-color: var(--text-muted);
  --input-ring-offset-width: 2px;
  --input-ring-width: 2px;
  --input-ring-color: var(--accent-color);
  --input-disabled-opacity: .5;
  --textarea-padding: .5rem 1rem;
  --textarea-border-radius: var(--border-radius-1);
  --mark-background-color: var(--accent-color);
}

@supports (color: color-mix(in lab, red, red)) {
  :root {
    --mark-background-color: color-mix(in srgb, var(--accent-color) 20%, transparent 80%);
  }
}

:root {
  --pre-background-color: #f2f4f6;
}

@media (max-width: 1200px) {
  :root {
    --content-padding-x: 2rem;
  }
}

@media (max-width: 768px) {
  :root {
    --content-padding-x: 1.25rem;
  }
}

[data-color-scheme="dark"] {
  --bg-color-0: #141414;
  --bg-color-1: var(--bg-color-0);
}

@supports (color: color-mix(in lab, red, red)) {
  [data-color-scheme="dark"] {
    --bg-color-1: color-mix(in srgb, var(--bg-color-0) 90%, white);
  }
}

[data-color-scheme="dark"] {
  --border-color-0: #ffffff14;
}

@supports (color: color-mix(in lab, red, red)) {
  [data-color-scheme="dark"] {
    --border-color-0: color-mix(in srgb, #ffffff14 98%, var(--accent-color));
  }
}

[data-color-scheme="dark"] {
  --text-color-0: #f8f8f8;
  --text-color-1: #e1e1e6;
  --text-color-2: #b4b4bd;
  --text-muted: #9f9faa;
  --tag-color: var(--text-color-1);
  --input-background-color: var(--bg-color-1);
}

@supports (color: color-mix(in lab, red, red)) {
  [data-color-scheme="dark"] {
    --input-background-color: color-mix(in srgb, var(--bg-color-1) 80%, transparent);
  }
}

[data-color-scheme="dark"] {
  --input-border-color: #ffffff1a;
  --input-placeholder-color: var(--text-muted);
  --input-ring-color: #ffffff80;
  --input-ring-width: 1px;
  --mark-background-color: var(--accent-color);
}

@supports (color: color-mix(in lab, red, red)) {
  [data-color-scheme="dark"] {
    --mark-background-color: color-mix(in srgb, var(--accent-color) 80%, transparent 20%);
  }
}

[data-color-scheme="dark"] .prose {
  --tw-prose-links: var(--color-bright-red) !important;
}

:root {
  transition: background-color .3s;
}

html {
  font-size: 16px;
  font-size: var(--rem-size);
  background-color: var(--bg-color-0);
}

@media (max-width: 768px) {
  html {
    overflow-x: hidden;
  }
}

html, body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-tap-highlight-color: transparent;
  accent-color: var(--accent-color);
  font-family: var(--font-family-body);
  font-style: normal;
  font-weight: var(--font-weight-body);
  line-height: var(--line-height-base);
  letter-spacing: var(--letter-spacing-body);
  font-optical-sizing: auto;
  color: var(--text-color-0);
  background-color: var(--bg-color-0);
  font-style: normal;
}

*, :before, :after {
  box-sizing: border-box;
  backface-visibility: hidden;
}

@view-transition {
  navigation: auto;
}

@media (prefers-reduced-motion) {
  ::view-transition-old(*) {
    animation: none;
  }

  ::view-transition-new(*) {
    animation: none;
  }
}

[hidden] {
  display: none !important;
}

hr {
  border-color: var(--border-color-0);
}

mark {
  background: var(--mark-background-color);
  color: inherit;
}

pre {
  background: var(--pre-background-color);
}

figure {
  flex-direction: column;
  justify-content: end;
  align-items: center;
  gap: .5rem;
  display: flex;
}

figure img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

figure figcaption {
  text-align: center;
  font-size: var(--font-size-s);
  letter-spacing: .02em;
  color: var(--text-color-2);
  justify-content: center;
  align-items: center;
  margin-top: 0;
  font-weight: 300;
  line-height: 1.5;
  display: flex;
}

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

p {
  font-family: var(--font-family-body);
  font-weight: var(--font-weight-body);
  letter-spacing: var(--letter-spacing-body);
  line-height: var(--line-height-base);
}

h1 {
  font-size: var(--font-size-h1);
  line-height: var(--line-height-h1);
}

h2 {
  font-size: var(--font-size-h2);
  line-height: var(--line-height-h2);
}

h3 {
  font-size: var(--font-size-h3);
  line-height: var(--line-height-h3);
}

h4 {
  font-size: var(--font-size-h4);
  line-height: var(--line-height-h4);
}

h5 {
  font-size: var(--font-size-h5);
  line-height: var(--line-height-h5);
}

h6 {
  font-size: var(--font-size-h6);
  line-height: var(--line-height-h6);
}

@keyframes fade-in-up {
  from {
    opacity: 0;
    transform: translateY(1rem);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: no-preference) {
  .fade-in-up {
    opacity: 0;
    animation: .3s ease-in-out forwards fade-in-up;
    transform: translateY(1rem);
  }
}

@font-face {
  font-weight: normal;
  font-display: block;
  font-family: icon-font;
  src: url("./fonts/icons.ttf") format("truetype"), url("./fonts/icons.svg") format("svg");
}

[data-icon]:before {
  word-wrap: normal;
  white-space: nowrap;
  text-transform: none;
  letter-spacing: normal;
  content: attr(data-icon);
  font-feature-settings: "liga";
  text-rendering: optimizeLegibility;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  direction: ltr;
  font-family: icon-font;
  font-size: 1.25em;
  font-style: normal;
  line-height: 1;
  display: flex;
}

button, .button, .kg-btn, .gh-post-upgrade-cta .gh-post-upgrade-cta-content a.gh-btn, [class$="-card-button"] {
  font-family: var(--font-family-body);
  letter-spacing: .01em;
  padding: var(--button-padding);
  height: var(--button-height);
  border-radius: var(--button-border-radius);
  border: var(--button-border);
  cursor: pointer;
  background: var(--button-background-color);
  text-align: center;
  white-space: nowrap;
  justify-content: center;
  align-items: center;
  gap: .25em;
  font-size: 1em;
  font-weight: 500;
  text-decoration: none;
  transition: all .15s ease-in-out;
  display: flex;
  color: lch(from var(--button-background-color) calc((49.44 - l) * infinity) 0 0) !important;
}

:is(button, .button, .kg-btn, .gh-post-upgrade-cta .gh-post-upgrade-cta-content a.gh-btn, [class$="-card-button"]):hover {
  opacity: .7;
}

:is(button, .button, .kg-btn, .gh-post-upgrade-cta .gh-post-upgrade-cta-content a.gh-btn, [class$="-card-button"]).button--alt {
  background: var(--button-secondary-background-color);
  border: var(--button-secondary-border);
  color: var(--button-secondary-color) !important;
}

:is(button, .button, .kg-btn, .gh-post-upgrade-cta .gh-post-upgrade-cta-content a.gh-btn, [class$="-card-button"]).button--destructive {
  color: var(--button-destructive-color);
  background: var(--button-destructive-background-color);
  border: var(--button-destructive-border);
}

:is(button, .button, .kg-btn, .gh-post-upgrade-cta .gh-post-upgrade-cta-content a.gh-btn, [class$="-card-button"])[disabled] {
  color: var(--button-disabled-color);
  background: var(--button-disabled-background-color);
  border: var(--button-disabled-border);
  cursor: not-allowed;
}

.input, input[type="text"], input[type="email"], input[type="password"], input[type="search"], input[type="tel"], input[type="url"], input[type="number"], textarea {
  width: 100%;
  height: var(--input-height);
  font-family: var(--font-family-body);
  font-size: var(--input-font-size);
  padding: var(--input-padding);
  color: var(--input-color);
  background: var(--input-background-color);
  border: 1px solid var(--input-border-color);
  border-radius: var(--input-border-radius);
  outline: none;
  transition: all .2s;
  display: flex;
  position: relative;
}

:is(.input, input[type="text"], input[type="email"], input[type="password"], input[type="search"], input[type="tel"], input[type="url"], input[type="number"], textarea)::file-selector-button {
  color: var(--input-color);
  background: none;
  border: 0;
  font-size: .875rem;
  font-weight: 500;
}

:is(.input, input[type="text"], input[type="email"], input[type="password"], input[type="search"], input[type="tel"], input[type="url"], input[type="number"], textarea)::-moz-placeholder {
  color: var(--input-placeholder-color);
}

:is(.input, input[type="text"], input[type="email"], input[type="password"], input[type="search"], input[type="tel"], input[type="url"], input[type="number"], textarea)::placeholder {
  color: var(--input-placeholder-color);
}

:is(.input, input[type="text"], input[type="email"], input[type="password"], input[type="search"], input[type="tel"], input[type="url"], input[type="number"], textarea):focus-visible {
  box-shadow: 0 0 0 var(--input-ring-offset-width) var(--bg-color-0), 0 0 0 calc(var(--input-ring-offset-width)  + var(--input-ring-width)) var(--input-ring-color);
  border-color: #0000;
  outline: none;
}

:is(.input, input[type="text"], input[type="email"], input[type="password"], input[type="search"], input[type="tel"], input[type="url"], input[type="number"], textarea):disabled {
  cursor: not-allowed;
  opacity: var(--input-disabled-opacity);
}

@media (max-width: 768px) {
  .input, input[type="text"], input[type="email"], input[type="password"], input[type="search"], input[type="tel"], input[type="url"], input[type="number"], textarea {
    font-size: var(--input-font-size-md);
  }
}

input[type="checkbox"] {
  width: 1.75rem;
  height: 1.75rem;
}

textarea {
  resize: none;
  border-radius: var(--textarea-border-radius);
  width: 100%;
  height: auto;
  padding: var(--textarea-padding);
}

:is(form, .form) [data-content] {
  display: none;
  overflow: hidden;
}

:is(form, .form) [data-content="default"] {
  display: block;
}

:is(:is(form, .form).loading, :is(form, .form).success, :is(form, .form).error) [data-content="default"] {
  display: none;
}

:is(:is(form, .form).loading, :is(form, .form).success, :is(form, .form).error) button[type="submit"] {
  opacity: .6;
  pointer-events: none;
}

:is(form, .form).loading [data-content="loading"], :is(form, .form).success [data-content="success"], :is(form, .form).error [data-content="error"] {
  display: block;
}

body .kg-image-card:not(.kg-width-full) {
  width: 100%;
}

body .kg-image-card:not(.kg-width-full) img {
  border-radius: var(--border-radius-2);
}

body .kg-image-card {
  z-index: 1;
  position: relative;
}

body .kg-image-card img {
  cursor: zoom-in;
  width: 100%;
  height: auto;
}

body .kg-width-wide {
  min-width: 100%;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  width: 75vw !important;
}

@media not all and (min-width: 50rem) {
  body .kg-width-wide {
    width: 100vw !important;
  }
}

body .kg-width-full {
  width: 100vw;
  position: relative;
  left: 50%;
  transform: translateX(-50vw);
}

body .kg-gallery-card figcaption p {
  margin: auto;
}

body .kg-gallery-container {
  z-index: 1;
  border-radius: var(--border-radius-2);
  position: relative;
  overflow: hidden;
}

body .kg-gallery-container img {
  cursor: zoom-in;
}

@media not all and (min-width: 50rem) {
  body .kg-gallery-container {
    border-radius: 0;
  }
}

body blockquote:not(.kg-blockquote-alt), body blockquote.kg-blockquote-alt {
  font-family: var(--font-family-heading);
  margin: 1rem auto;
  font-size: 1.5rem;
  font-style: italic;
  font-weight: 500;
  line-height: 1.5;
}

body blockquote:not(.kg-blockquote-alt) {
  border-left: .25rem solid var(--accent-color);
  padding: 1rem 1rem 1rem 3rem;
}

body blockquote.kg-blockquote-alt {
  text-align: center;
  border: none;
  padding: 1rem 3rem;
  position: relative;
}

body blockquote.kg-blockquote-alt:before, body blockquote.kg-blockquote-alt:after {
  width: 4rem;
  font-family: Arial Black, Arial Bold, sans-serif;
  font-size: 4rem;
  line-height: 0;
  position: absolute;
}

body blockquote.kg-blockquote-alt:before {
  content: "“";
  top: 1.5rem;
  left: -1rem;
}

body blockquote.kg-blockquote-alt:after {
  content: "”";
  text-align: left;
  bottom: .5rem;
  right: -.5rem;
}

body .kg-audio-card {
  border-radius: var(--border-radius-2);
  width: 100%;
  padding: 1.5rem;
  overflow: hidden;
}

body .kg-audio-card .kg-audio-thumbnail {
  aspect-ratio: 1;
  border-radius: var(--border-radius-1);
  width: 15rem;
  max-width: 15rem;
  margin: 0;
}

body .kg-audio-card button {
  color: var(--text-color-0) !important;
}

body .kg-audio-card .kg-audio-player-container {
  justify-content: space-around;
  gap: 1rem;
  padding: 1rem 0 1rem 2rem;
}

body .kg-audio-card .kg-audio-title, body .kg-audio-card .kg-audio-player {
  margin: 0;
  padding: 0;
}

body .kg-audio-card .kg-audio-title {
  font-size: 2rem;
}

body .kg-audio-card .kg-audio-player {
  flex-grow: initial;
}

body .kg-audio-card button {
  height: auto;
}

body .kg-callout-card {
  border-radius: var(--border-radius-2);
  padding: 1.5rem;
}

body .kg-callout-card div.kg-callout-emoji {
  padding-right: 1.5rem;
  font-size: 1.5rem;
}

body .kg-callout-card div.kg-callout-text {
  font-size: 1rem;
}

body .kg-video-card .kg-video-container {
  border-radius: var(--border-radius-2);
  overflow: hidden;
}

body .kg-video-card .kg-video-player {
  padding: 1rem 1.5rem;
}

body .kg-header-card picture {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

body .kg-bookmark-card a.kg-bookmark-container {
  border-color: var(--border-color-0);
  border-radius: var(--border-radius-2) !important;
}

body .kg-bookmark-card .kg-bookmark-content {
  padding: 1.5rem;
}

body .kg-bookmark-card .kg-bookmark-thumbnail img {
  margin: auto;
}

body .kg-bookmark-card .kg-bookmark-metadata {
  height: 1.5rem;
  margin-top: 1.5rem;
  font-size: 1rem;
}

body .kg-bookmark-card figcaption p {
  margin: auto;
}

body .kg-product-card {
  font-family: var(--font-family-body);
}

body .kg-product-card .kg-product-card-container {
  border-radius: var(--border-radius-2);
  grid-row-gap: 1.5rem;
  border-color: var(--border-color-0);
  max-width: 30rem;
  padding: 1.5rem;
  font-family: inherit;
}

body .kg-product-card .kg-product-card-container img {
  border-radius: var(--border-radius-1);
  width: 100%;
  margin: auto;
}

body .kg-product-card h4.kg-product-card-title {
  font-size: var(--font-size-h3);
  line-height: var(--line-height-h3);
  margin: 0;
}

body .kg-product-card .kg-product-card-rating {
  align-self: center;
}

body .kg-file-card a.kg-file-card-container {
  border-radius: var(--border-radius-2);
  padding: 1.5rem;
}

body .kg-file-card .kg-file-card-icon {
  aspect-ratio: 1;
  width: 10rem;
}

body .kg-file-card .kg-file-card-icon svg {
  color: inherit;
}

body .kg-file-card .kg-file-card-icon:before {
  border-radius: var(--border-radius-1);
}

body .kg-toggle-card {
  border-radius: var(--border-radius-2);
  box-shadow: none;
  border: 1px solid var(--border-color-0);
  padding: 1.5rem;
}

body .kg-toggle-card .kg-toggle-heading {
  transition: margin-bottom .2s ease-in-out;
}

body .kg-toggle-card[data-kg-toggle-state="close"] .kg-toggle-heading-text {
  margin-bottom: 0 !important;
}

body .gh-post-upgrade-cta {
  border: 1px solid var(--border-color-0);
  border-radius: var(--border-radius-2);
  margin-bottom: 4rem;
  transition: box-shadow .3s ease-in-out;
  position: relative;
  box-shadow: 0 4px 12px #00000014;
}

body .gh-post-upgrade-cta .gh-post-upgrade-cta-content {
  border-radius: inherit;
  color: var(--text-color-0);
  margin: auto;
  padding: 2.5rem 2rem 2rem;
  background: none !important;
}

body .gh-post-upgrade-cta .gh-post-upgrade-cta-content h2 {
  color: var(--text-color-0);
  font-size: var(--font-size-h4);
  line-height: var(--line-height-h4);
  letter-spacing: var(--letter-spacing-heading);
}

body .gh-post-upgrade-cta .gh-post-upgrade-cta-content p small {
  color: var(--text-color-1);
  font-size: var(--font-size-base);
  letter-spacing: var(--letter-spacing-body);
  line-height: 1;
}

body .gh-post-upgrade-cta .gh-post-upgrade-cta-content a:not(.gh-btn) {
  color: var(--accent-color);
}

body .gh-post-upgrade-cta:hover {
  box-shadow: 0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;
}

body .gh-post-upgrade-cta:before {
  content: "";
  background: linear-gradient(to bottom, #fff0 0%, var(--bg-color-0) 85%);
  pointer-events: none;
  height: 10rem;
  position: absolute;
  top: -10.5rem;
  left: 0;
  right: 0;
}

body iframe[src*="open.spotify.com"] {
  margin-bottom: 2rem !important;
}

body .kg-bookmark-container, body .kg-product-card-container, body .kg-audio-card, body .kg-file-card-container, body .kg-toggle-card, body .gh-post-upgrade-cta, body .kg-file-card-container {
  background: var(--bg-color-1) !important;
  color: var(--text-color-0) !important;
}

.container {
  max-width: var(--content-max-width);
  padding: 0 var(--content-padding-x);
  width: 100%;
  margin: 0 auto;
}

.section {
  padding: 4rem 0;
  position: relative;
}

.toc-item.hash-toc-starter {
  order: 1;
}

.toc-item.hash-toc-up-front {
  order: 2;
}

.toc-item.hash-toc-articles {
  order: 3;
}

.toc-item.hash-toc-special-reports {
  order: 4;
}

.toc-item.hash-toc-reviews {
  order: 5;
}

.toc-item.hash-toc-in-memoriam {
  order: 20;
}

.toc-item.hash-toc-starter .toc-group-title, .toc-item.hash-toc-up-front + .toc-item.hash-toc-up-front .toc-group-title, .toc-item.hash-toc-articles + .toc-item.hash-toc-articles .toc-group-title, .toc-item.hash-toc-special-reports + .toc-item.hash-toc-special-reports .toc-group-title, .toc-item.hash-toc-reviews + .toc-item.hash-toc-reviews .toc-group-title, .toc-item.hash-toc-in-memoriam + .toc-item.hash-toc-in-memoriam .toc-group-title {
  display: none;
}

.toc-item .toc-group-title {
  margin-top: 1em;
  margin-bottom: .5em;
  font-size: 1.2em;
  font-weight: 600;
}

a[href="/author/unidentified-author/"], a[href="/author/example-author"] {
  display: none !important;
}

a.toc-item-title {
  color: var(--color-darker-red);
  font-size: 1.1rem;
  font-weight: bold;
}

span.dot-separator:first-child {
  display: none;
}

.book-layout-style a {
  color: var(--color-darker-red);
  text-decoration: underline;
}

@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

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

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

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

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

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

@property --tw-scroll-snap-strictness {
  syntax: "*";
  inherits: false;
  initial-value: proximity;
}

@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

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

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

@property --tw-tracking {
  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;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@property --tw-backdrop-hue-rotate {
  syntax: "*";
  inherits: false
}

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

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

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

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

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

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

@property --tw-scale-x {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-scale-y {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-scale-z {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
