Real Vim ninjas count every keystroke - do you?

Pick a challenge, fire up Vim, and show us what you got.

Changelog, Rules & FAQ, updates: @vimgolf, RSS.

Your VimGolf key: please sign in

$ gem install vimgolf
$ vimgolf setup
$ vimgolf put 9v0067a47b9200000000069f

Reordering properties

Arrange the CSS lines for the #topbar selector based on their complete line length, from shortest to longest.

Start file
#topbar {
  background-image: url("images/abc.png");
  background-position: 12px 13px;
  font-size: 1px;
  left: 36px;
  margin-top: 10px;
  position: relative;
  top: 23px;
  vertical-align: middle;
  width: 200px;
}

#topbar .logo {
  top: 50%;
  position: absolute;
  left: 20px;
  transform: translateY(-50%);
  font-size: 28px;
  font-weight: bold;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 1px;
}
End file
#topbar {
  top: 23px;
  left: 36px;
  width: 200px;
  font-size: 1px;
  margin-top: 10px;
  position: relative;
  vertical-align: middle;
  background-position: 12px 13px;
  background-image: url("images/abc.png");
}

#topbar .logo {
  top: 50%;
  left: 20px;
  color: #fff;
  font-size: 28px;
  font-weight: bold;
  position: absolute;
  letter-spacing: 1px;
  text-transform: uppercase;
  transform: translateY(-50%);
}

View Diff

2,4c2
<   background-image: url("images/abc.png");
<   background-position: 12px 13px;
<   font-size: 1px;
---
>   top: 23px;
5a4,5
>   width: 200px;
>   font-size: 1px;
8d7
<   top: 23px;
10c9,10
<   width: 200px;
---
>   background-position: 12px 13px;
>   background-image: url("images/abc.png");
15d14
<   position: absolute;
17c16
<   transform: translateY(-50%);
---
>   color: #fff;
20,21c19
<   color: #fff;
<   text-transform: uppercase;
---
>   position: absolute;
22a21,22
>   text-transform: uppercase;
>   transform: translateY(-50%);

Solutions by @KapJI:

Unlock 12 remaining solutions by signing in and submitting your own entry
Created by: @maharba6

293 active golfers, 1308 entries

Solutions by @KapJI:
25
#16 - Ruslan Sayfutdinov / @KapJI

05/29/2026 at 12:45PM

29
#>18 - Ruslan Sayfutdinov / @KapJI

05/29/2026 at 12:32PM

31
#>24 - Ruslan Sayfutdinov / @KapJI

05/29/2026 at 12:26PM

35
#>27 - Ruslan Sayfutdinov / @KapJI

05/29/2026 at 12:12PM

36
#>28 - Ruslan Sayfutdinov / @KapJI

05/29/2026 at 11:50AM

37
#>32 - Ruslan Sayfutdinov / @KapJI

05/29/2026 at 11:43AM

38
#>41 - Ruslan Sayfutdinov / @KapJI

05/29/2026 at 09:26AM

40
#>51 - Ruslan Sayfutdinov / @KapJI

05/29/2026 at 08:54AM

44
#>65 - Ruslan Sayfutdinov / @KapJI

05/29/2026 at 08:16AM

48
#>76 - Ruslan Sayfutdinov / @KapJI

05/29/2026 at 12:08AM

50
#>80 - Ruslan Sayfutdinov / @KapJI

05/29/2026 at 12:06AM

52
#>84 - Ruslan Sayfutdinov / @KapJI

05/28/2026 at 11:38PM