@layer blocks {
  .task-item {
    --task-item-z-index: 1;
    position: relative;
    z-index: var(--task-item-z-index);
    padding: var(--space-2xs);
    border-radius: var(--radius-m);
    background: transparent;
    cursor: pointer;
    transition: background 0.15s;
    border: none;
    --repel-gap: var(--space-2xs);
  }

  .task-item:hover {
    background: var(--brand-pale-light);
  }

  .task-item .checkbox {
    margin-inline-end: 0;
  }

  .task-item-content {
    flex: 1;
    min-width: 0;
    line-height: var(--leading-snug);
  }

  .task-item-content .hashes {
    margin-left: var(--space-3xs);
  }

  .task-item-link {
    position: static;
    color: inherit;
    --link-decoration: none;
  }

  .task-item-link::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: var(--task-item-z-index);
  }

  .task-item :where(a, button, input, select, textarea, [tabindex]):not(.task-item-link) {
    position: relative;
    z-index: calc(var(--task-item-z-index) + 1);
  }

  /* Focus handling */
  .task-item:focus-within {
    outline: 1px solid var(--color-focus-border);
    outline-offset: 1px;
  }

  .task-item:focus-within:has(:focus-visible) {
    outline: 1px solid var(--color-focus-border);
    outline-offset: 1px;
  }

  .task-item:focus-within:not(:has(:focus-visible)) {
    outline: none;
  }

  .task-item-link:focus-visible {
    outline: none;
  }

  /* Completing animation */
  @keyframes task-complete {
    0% {
      opacity: 1;
      transform: translateX(0);
    }
    70% {
      opacity: 0.5;
      transform: translateX(0);
    }
    100% {
      opacity: 0;
      transform: translateX(1rem);
      max-height: 0;
      padding: 0;
      margin: 0;
      overflow: hidden;
    }
  }

  .task-item.completing {
    animation: task-complete 0.4s ease-out forwards;
  }

  .task-item.completing .title {
    text-decoration: line-through;
    color: var(--text-4);
  }

  .task-item.completing .checkbox {
    background: var(--color-accent);
    border-color: var(--color-accent);
  }

  .task-item.completing .badge {
    opacity: 0.5;
  }

  .task-item[data-state="ghost"] {
    border: 1px dashed var(--brand-soft);
    opacity: 0.5;
    margin-top: var(--space-3xs);
  }

  .task-item[data-state="ghost"] .button {
    padding: 0 0.375rem;
    margin-block-start: 0;
  }
}
