Pen Settings

HTML

CSS

CSS Base

Vendor Prefixing

Add External Stylesheets/Pens

Any URLs added here will be added as <link>s in order, and before the CSS in the editor. You can use the CSS from another Pen by using its URL and the proper URL extension.

+ add another resource

JavaScript

Babel includes JSX processing.

Add External Scripts/Pens

Any URL's added here will be added as <script>s in order, and run before the JavaScript in the editor. You can use the URL of any other Pen and it will include the JavaScript from that Pen.

+ add another resource

Packages

Add Packages

Search for and use JavaScript packages from npm here. By selecting a package, an import statement will be added to the top of the JavaScript editor for this package.

Behavior

Auto Save

If active, Pens will autosave every 30 seconds after being saved once.

Auto-Updating Preview

If enabled, the preview panel updates automatically as you code. If disabled, use the "Run" button to update.

Format on Save

If enabled, your code will be formatted when you actively save your Pen. Note: your code becomes un-folded during formatting.

Editor Settings

Code Indentation

Want to change your Syntax Highlighting theme, Fonts and more?

Visit your global Editor Settings.

HTML

              
                - @diskFiles = [{"label" => "folder", "name" => "Dos", "for" => "explorer-dos"}, {"label" => "folder", "name" => "Program Files", "for" => "explorer-program-files"}, {"label" => "folder", "name" => "Windows", "for" => "explorer-windows"}, {"label" => "program-config", "name" => "Autoexec"}, {"label" => "document-windows", "name" => "Autoexec.dos"}, {"label" => "program", "name" => "Command"}, {"label" => "document-windows", "name" => "Command.dos"}, {"label" => "document-windows", "name" => "Config.dos"}, {"label" => "program-config", "name" => "Dbg"}, {"label" => "document-text", "name" => "Netlog"}, {"label" => "program", "name" => "Wdeb386"}]

- @programFiles = ["Microsoft Exchange", "The Microsoft Network"]

- @windowsFolders = ["Command", "Config", "Cursors", "Fonts", "Help", "Media", "SendTo", "Start Menu", "System", "Temp"]

- @windowsFiles = [{"label" => "document-misc", "name" => "Accessor"}, { "label" => "document-windows", "name" => "Black Thatch"}, {"label" => "document-windows", "name" => "Blue Rivets"}, {"label" => "document-windows", "name" => "Bubbles"}, {"label" => "document-windows", "name" => "Carved Stone"}, {"label" => "document-windows", "name" => "Circles"}, {"label" => "program", "name" => "Command"}, {"label" => "document-text", "name" => "Config"}, {"label" => "program", "name" => "Control"}, {"label" => "document-text", "name" => "Control"}, {"label" => "document-misc", "name" => "Desktop"}, {"label" => "document-text", "name" => "Display"}, {"label" => "document-misc", "name" => "Document"}, {"label" => "program", "name" => "Dosprmpt"}, {"label" => "program", "name" => "Emm386"}, {"label" => "document-text", "name" => "Exchange"}, {"label" => "document-misc", "name" => "Exchng32"}, {"label" => "computer", "name" => "Explorer"}, {"label" => "document-text", "name" => "Extra"}, {"label" => "document-text", "name" => "Faq"}, {"label" => "document-font", "name" => "Fontview"}, {"label" => "document-text", "name" => "General"}, {"label" => "grpconv", "name" => "Grpconv"}]

- @controlPanelItems = [{"label" => "hardware", "name" => "Add New Hardware"}, {"label" => "add-programs", "name" => "Add/Remove Programs"}, {"label" => "date-time", "name" => "Date/Time"}, {"label" => "computer-display", "name" => "Display"}, {"label" => "folder-fonts-link", "name" => "Fonts"}, {"label" => "internet", "name" => "Internet"}, {"label" => "joystick", "name" => "Joystick"}, {"label" => "keyboard", "name" => "Keyboard"}, {"label" => "inbox", "name" => "Mail"}, {"label" => "modems", "name" => "Modems"}, {"label" => "mouse", "name" => "Mouse"}, {"label" => "multimedia", "name" => "Multimedia"}, {"label" => "network", "name" => "Network"}, {"label" => "passwords", "name" => "Passwords"}, {"label" => "battery", "name" => "Power"}, {"label" => "folder-printers-link", "name" => "Printers", "for" => "explorer-printers"}, {"label" => "regional", "name" => "Regional Settings"}, {"label" => "computer-sounds", "name" => "Sounds"}, {"label" => "computer-mouse", "name" => "System"}]

- @dosFiles = [{"label" => "document-windows", "name" => "4201.cpi"}, {"label" => "document-windows", "name" => "4208.cpi"}, {"label" => "document-windows", "name" => "5202.cpi"}, {"label" => "program", "name" => "Append"}, {"label" => "document-text", "name" => "Appnotes"}, {"label" => "program", "name" => "Assign"}, {"label" => "program", "name" => "Attrib"}, {"label" => "program", "name" => "Backup"}, {"label" => "program", "name" => "Chkdsk"}, {"label" => "program", "name" => "Command"}, {"label" => "program", "name" => "Comp"}, {"label" => "program-config", "name" => "Dblspace"}, {"label" => "program", "name" => "Debug"}, {"label" => "program-config", "name" => "Defrag"}, {"label" => "program", "name" => "Diskcomp"}, {"label" => "program", "name" => "Diskcopy"}, {"label" => "help", "name" => "Doshelp"}, {"label" => "program", "name" => "Doskey"}, {"label" => "program", "name" => "Dosshell"}, {"label" => "program", "name" => "Dosshell"}, {"label" => "document-windows", "name" => "Dosshell.grb"}, {"label" => "help", "name" => "Dosshell"}, {"label" => "document-text", "name" => "Dosshell"}, {"label" => "document-windows", "name" => "Dosshell.vid"}, {"label" => "program", "name" => "Dosswap"}, {"label" => "program-config", "name" => "Drvspace"}, {"label" => "program", "name" => "Edit"}]

- @optionInputs = [{"name" => "always-on-top", "checked" => true}, {"name" => "auto-hide"}, {"name" => "show-small-icons"}, {"name" => "show-clock", "checked" => true}]

- @editPartial = '<li><label class="label-disabled">Undo</label></li><li><hr></li><li><label class="label-disabled"><span><span>Cu</span><span class="line">t</span></span></label></li><li><label class="label-disabled">Copy</label></li><li><label class="label-disabled">Paste</label></li>'

- @editMenu = '<li><label class="label-disabled"><span><span>Paste&nbsp;</span><span class="line">Shortcut</span></span></label></li><li><hr></li><li><label class="label-disabled"><span><span>Select&nbsp;</span><span class="line">All</span></span></label></li><li><label class="label-disabled">Invert Selection</label></li>'

- @viewMenu = '<li><a class="label-nested"><span><span>Arrange&nbsp;</span><span class="line">Icons</span></span></a><menu class="sub-menu underline"><li><label class="label-disabled"><span><span>by&nbsp;</span><span class="line">Name</span></span></label></li><li><label class="label-disabled"><span><span>by&nbsp;</span><span class="line">Type</span></span></label></li><li><label class="label-disabled"><span><span>by&nbsp;Si</span><span class="line">ze</span></span></label></li><li><label class="label-disabled"><span><span>by&nbsp;</span><span class="line">Date</span></span></label></li><li><hr></li><li><label class="label-disabled">Auto Arrange</label></li></menu></li><li><label class="label-disabled"><span><span>Lin</span><span class="line">e up Icons</span></span></label></li><li><hr></li><li><label class="label-disabled">Refresh</label></li><li><label class="label-disabled">Options...</label></li>'

- @helpMenu = '<menu class="sub-menu underline"><li><label class="label-disabled">Help Topics</label></li><li><hr></li><li><label class="label-disabled">About Windows 95</label></li></menu>'

%input#start{:type => "checkbox", "data-start" => true, :hidden => true}

- @optionInputs.each do |input|
	- if (input['checked'] == true)
		%input{:id => "global-option-#{input['name']}", :type => "checkbox", :hidden => true, "data-global-option" => true, :checked => true}
	- else
		%input{:id => "global-option-#{input['name']}", :type => "checkbox", :hidden => true, "data-global-option" => true}

- @windowInputs = [{"name" => "welcome", "checked" => true, "static" => true}, {"name" => "taskbar", "static" => true}, {"name" => "printers"}, {"name" => "control-panel"}, {"name" => "computer"}, {"name" => "notepad"}, {"name" => "explorer"}]
- @windowInputs.each do |input|
	- if (input['static'] != true)
		%input{:id => "#{input['name']}", :type => "checkbox", "data-window-trigger" => true, "data-name" => "#{input['name']}", :hidden => true}
		%input{:id => "#{input['name']}-minimize", :type => "checkbox", "data-minimize" => true, "data-name" => "#{input['name']}", :hidden => true}
		%input{:id => "#{input['name']}-maximize", :type => "checkbox", "data-maximize" => true, "data-name" => "#{input['name']}", :hidden => true}
	- else
		- if (input['checked'] == true)
			%input.no-tab.active{:id => "#{input['name']}", :type => "checkbox", "data-window-trigger" => true, "data-name" => "#{input['name']}", :hidden => true, :checked => true}
		- else
			%input.no-tab{:id => "#{input['name']}", :type => "checkbox", "data-window-trigger" => true, "data-name" => "#{input['name']}", :hidden => true}

- @explorerInputs = [{"name" => "desktop"}, {"name" => "computer"}, {"name" => "disk", "checked" => true}, {"name" => "dos"}, {"name" => "program-files"}, {"name" => "windows"}, {"name" => "control-panel"}, {"name" => "printers"}, {"name" => "recycle-bin"}]
- @explorerInputs.each do |input|
	- if input['checked']
		%input{:id => "explorer-#{input['name']}", :type => "radio", :name => "explorer", :checked => true, :hidden => true}
	- else
		%input{:id => "explorer-#{input['name']}", :type => "radio", :name => "explorer", :hidden => true}

%input#toggle-computer{:type => "checkbox", :checked => true, :hidden => true}
%input#toggle-disk{:type => "checkbox", :checked => true, :hidden => true}
%input#toggle-program-files{:type => "checkbox", :hidden => true}
%input#toggle-windows{:type => "checkbox", :hidden => true}

%input#error-diskette-a{:type => "checkbox", :hidden => true, "data-error-trigger" => true, "data-name" => "diskette-a"}
%input#error-diskette-b{:type => "checkbox", :hidden => true, "data-error-trigger" => true, "data-name" => "diskette-b"}
%input#error-blue-screen{:type => "checkbox", :hidden => true, "data-error-trigger" => true, "data-name" => "blue-screen"}

%main
	#desktop
		#icons
			%label.desktop-icon.label-computer{:tabindex => 0, :for => "computer"}
				%span My Computer
			%label.desktop-icon.label-inbox
				%span Inbox
			%label.desktop-icon.label-recycle-bin
				%span Recycle Bin

		#windows
			#window-welcome.window{"data-window" => true}
				.window-inside
					%nav.window-nav
						%h3
							%span Welcome
						.buttons
							%label.close{:for => "welcome", :tabindex => 0}
					.window-content
						.information-container
							.information
								%h3 About this project
								%p This ongoing web experiment by <a href="https://gabriellew.ee" target="_blank">Gabrielle Wee</a> is an attempt to get as close as possible to Windows&nbsp;95 using primarily CSS and HTML, with a little bit of Javascript magic.

								%h3 Changelog
								%ul
									%li October 12, 2023 - Fix bug where window cannot maximize after resizing
									%li September 19, 2023 - Launch first version!
									%li March 10, 2023 - Begin experiment.

								%h3 Caveats
								%ul
									%li The code is pretty convoluted and difficult to follow. It’s not really meant to be an example of best practices!
									%li On that note, this demo works best in a desktop view. It may work on mobile devices but not all windows will function properly.
									%li Items that are not selectable are not functional (yet).
									%li There’s some weird sizing issues that mean that this demo is not 1:1 with actual Windows&nbsp;95 and that’s ok!
									%li This demo may not be accessible or easy to navigate using the keyboard.
									%li Most of the components work without Javascript, but everything works better with Javascript.
									%li There are a few bugs that I haven’t ironed out yet. If you notice one, I’m probably in the process of fixing it!

								%h3 To-do
								%ul
									%li Iron out bugs. Always.
									%li Add documents to the Documents menu
									%li Add Inbox and Recycle Bin windows
									%li Add Find and Run options from Start menu
									%li Enable buttons in Taskbar window on the Start Menu Programs tab
									%li Enable tooltips in Taskbar window
									%li Enabled status bar tips
									%li Get window resizing working on most windows
									%li Add window stacking when new windows are opened
									%li Add shut down sequence

								%h3 Credits
								%ul
									%li <a href="https://www.pcjs.org/software/pcx86/sys/windows/win95/4.00.950/" target="_blank">Windows 95 emulator</a>
									%li <a href="https://codepen.io/louh/pen/oZJQvm" target="_blank">Windows&nbsp;95 scrollbars</a>
									%li Icons are modified from the original Windows&nbsp;95 icons

					.window-footer
						%label.button{:for => "welcome", :tabindex => 0}
							%span Close
									
									

			#window-taskbar.window{"data-window" => true}
				%input#taskbar-options{:type => "radio", :name => "taskbar", :hidden => true, :checked => true}
				%input#start-menu-programs{:type => "radio", :name => "taskbar", :hidden => true}
				
				- @optionInputs.each do |input|
					- if (input['checked'] == true)
						%input{:id => "option-#{input['name']}", :type => "checkbox", :hidden => true, "data-option" => true, :checked => true}
					- else
						%input{:id => "option-#{input['name']}", :type => "checkbox", "data-option" => true, :hidden => true}

				.window-inside
					%nav.window-nav
						%h3
							%span Taskbar Properties
						.buttons
							%label.question{:tabindex => 0, :disabled => true}
							%label.close{:for => "taskbar", :tabindex => 0}
					.window-content
						.tab-container
							.tab-group
								%label.tab.tab-taskbar-options{:for => "taskbar-options"}
									%span Taskbar Options
								%label.tab.tab-start-menu-programs{:for => "start-menu-programs"}
									%span Start Menu Programs
							.tabpanel-group
								.tabpanel.taskbar-options
									.preview-container
										.preview
											.window
												.window-inside
													.window-content
														.list-container
															%menu.list
																%li
																	%label{:class => "label-volume"} Sound Re
																%li
																	%label{:class => "label-wordpad"} Wordpad
											.start-menu-outline
											%nav.start-menu
												%label.label-start Start
												.menu-container
													%menu.menu.main-menu.underline
														%li
															%a.label-settings.label-nested
																%span Settings
														%li
															%a.label-find.label-nested
																%span Find
														%li
															%label.label-help
																%span Help
														%li
															%label.label-run
																%span Run...
														%li
															%label.label-shut-down
																%span
																	%span> Sh
																	%span.line> u
																	%span> t Down
												.time.label-printer-small
													%time 12:45 PM
									%menu.options.underline
										%li
											%label{:for => "option-always-on-top", :tabindex => 0}
												%span
													%span Always on
													%span.line top
										%li
											%label{:for => "option-auto-hide", :tabindex => 0}
												%span
													%span> A
													%span.line> u
													%span> to hide
										%li
											%label{:for => "option-show-small-icons", :tabindex => 0}
												%span
													%span Show
													%span.line small
													%span icons in Start menu
										%li
											%label{:for => "option-show-clock", :tabindex => 0}
												%span
													%span Show
													%span.line Clock
								.tabpanel.start-menu-programs
									%form
										%fieldset.customize-start-menu
											%legend Customize Start Menu
											%p.label-customize-start-menu You may customize your Start Menu by adding or removing items from it.
											%menu.menu-options.underline
												%li
													%label.button{:disabled => true, :tabindex => 0}
														%span Add…
												%li
													%label.button{:disabled => true, :tabindex => 0}
														%span Remove…
												%li
													%label.button{:disabled => true, :tabindex => 0}
														%span
															%span> A
															%span.line> dvanced…
										%fieldset.documents-menu
											%legend Documents Menu
											%p.label-recycle-bin-folder Click the clear button to remove the contents of the Documents Menu.
											%menu.menu-options.underline
												%li
													%label.button{:disabled => true, :for => "clear-documents", :tabindex => 0}
														%span Clear
					.window-footer
						%label.button{:for => "taskbar", :tabindex => 0, :disabled => true, "data-apply" => true, "data-close" => true}
							%span OK
						%label.button{:for => "taskbar", :tabindex => 0}
							%span Cancel
						%label.button.underline{:disabled => true, "data-apply" => true}
							%span Apply

			#window-printers.window{"data-window" => true}
				%input.toggle-menu{:id => "printers-menu", :type => "checkbox", :hidden => true, "data-menu" => true}

				%input#printers-menu-status-bar.menu-status-bar{:type => "checkbox", :checked => true, :hidden => true}

				%input#printers-menu-large-icons.menu-large-icons{:type => "radio", :name => "printers-icon-size", :checked => true, :hidden => true}
				%input#printers-menu-small-icons.menu-small-icons{:type => "radio", :name => "printers-icon-size", :hidden => true}
				%input#printers-menu-list-icons.menu-list-icons{:type => "radio", :name => "printers-icon-size", :hidden => true}

				.window-inside
					%nav.window-nav
						%h3.label-folder-printers-small
							%span Printers
						.buttons
							%label.minimize{:for => "printers-minimize", :tabindex => 0}
							%label.maximize{:for => "printers-maximize", :tabindex => 0}
							%label.close{:for => "printers", :tabindex => 0}
					%menu.window-menu.underline
						%label.toggle-menu-label{:for => "printers-menu", "data-toggle" => true}
						%li
							%a.menu-item-file{:href => "#", "data-label" => true} File
							%menu.sub-menu.underline
								%li
									%label.label-disabled
										%span
											%span> Create&nbsp;
											%span.line> Shortcut
								%li
									%label.label-disabled Delete
								%li
									%label.label-disabled
										%span
											%span> Rena
											%span.line> me
								%li
									%label.label-disabled Properties
								%li
									%hr
								%li
									%label{:for => "printers", :tabindex => 0} Close
						%li
							%a.menu-item-edit{:href => "#", "data-label" => true} Edit
							%menu.sub-menu.underline
								#{@editPartial}
								#{@editMenu}
						%li
							%a.menu-item-view{:href => "#", "data-label" => true} View
							%menu.sub-menu.underline
								%li
									%label.label-disabled Toolbar
								%li
									%label.label-check.label-status-bar{:for => "printers-menu-status-bar"}
										%span
											%span> Status&nbsp;
											%span.line> Bar
								%li
									%hr
								%li
									%label.label-check.label-icon-size.label-large-icons{:for => "printers-menu-large-icons"}
										%span
											%span> Lar
											%span.line> ge Icons
								%li
									%label.label-check.label-icon-size.label-small-icons{:for => "printers-menu-small-icons"}
										%span
											%span> S
											%span.line> mall Icons
								%li
									%label.label-check.label-icon-size.label-list-icons{:for => "printers-menu-list-icons"}
										%span.line List
								#{@viewMenu}
						%li
							%a.menu-item-help{:href => "#", "data-label" => true} Help
							#{@helpMenu}
					.window-content
						.list-container.above-footer
							%menu.list
								%li
									%label.label-document-printer-small Add Printer
						%footer.window-footer
							%ul.number
								%li.show 1 object(s)

			#window-control-panel.window{"data-window" => true}
				%input.toggle-menu{:id => "control-panel-menu", :type => "checkbox", :hidden => true, "data-menu" => true}

				%input#control-panel-menu-status-bar.menu-status-bar{:type => "checkbox", :checked => true, :hidden => true}

				%input#control-panel-menu-large-icons.menu-large-icons{:type => "radio", :name => "control-panel-icon-size", :checked => true, :hidden => true}
				%input#control-panel-menu-small-icons.menu-small-icons{:type => "radio", :name => "control-panel-icon-size", :hidden => true}
				%input#control-panel-menu-list-icons.menu-list-icons{:type => "radio", :name => "control-panel-icon-size", :hidden => true}
				
				.window-inside
					%nav.window-nav
						%h3.label-control-panel-small
							%span Control Panel
						.buttons
							%label.minimize{:for => "control-panel-minimize", :tabindex => 0}
							%label.maximize{:for => "control-panel-maximize", :tabindex => 0}
							%label.close{:for => "control-panel", :tabindex => 0}
					%menu.window-menu.underline
						%label.toggle-menu-label{:for => "control-panel-menu", "data-toggle" => true}
						%li
							%a.menu-item-file{:href => "#", "data-label" => true} File
							%menu.sub-menu.underline
								%li
									%label.label-disabled
										%span
											%span> Create&nbsp;
											%span.line> Shortcut
								%li
									%label.label-disabled Delete
								%li
									%label.label-disabled
										%span
											%span> Rena
											%span.line> me
								%li
									%label.label-disabled Properties
								%li
									%hr
								%li
									%label{:for => "control-panel", :tabindex => 0} Close
						%li
							%a.menu-item-edit{:href => "#", "data-label" => true} Edit
							%menu.sub-menu.underline
								#{@editPartial}
								#{@editMenu}
						%li
							%a.menu-item-view{:href => "#", "data-label" => true} View
							%menu.sub-menu.underline
								%li
									%label.label-disabled Toolbar
								%li
									%label.label-check.label-status-bar{:for => "control-panel-menu-status-bar"}
										%span
											%span> Status&nbsp;
											%span.line> Bar
								%li
									%hr
								%li
									%label.label-check.label-icon-size.label-large-icons{:for => "control-panel-menu-large-icons"}
										%span
											%span> Lar
											%span.line> ge Icons
								%li
									%label.label-check.label-icon-size.label-small-icons{:for => "control-panel-menu-small-icons"}
										%span
											%span> S
											%span.line> mall Icons
								%li
									%label.label-check.label-icon-size.label-list-icons{:for => "control-panel-menu-list-icons"}
										%span.line List
								#{@viewMenu}
						%li
							%a.menu-item-help{:href => "#", "data-label" => true} Help
							#{@helpMenu}
					.window-content
						.list-container.above-footer
							%menu.list
								- @controlPanelItems.each do |item|
									%li
										%label{:class => "label-#{item['label']}-small"} #{item['name']}
						%footer.window-footer
							%ul.number
								%li.show 19 object(s)

			#window-computer.window.window-default{"data-window" => true}
				%input.toggle-menu{:id => "computer-menu", :type => "checkbox", :hidden => true, "data-menu" => true}

				%input#computer-menu-status-bar.menu-status-bar{:type => "checkbox", :checked => true, :hidden => true}

				%input#computer-menu-large-icons.menu-large-icons{:type => "radio", :name => "computer-icon-size", :checked => true, :hidden => true}
				%input#computer-menu-small-icons.menu-small-icons{:type => "radio", :name => "computer-icon-size", :hidden => true}
				%input#computer-menu-list-icons.menu-list-icons{:type => "radio", :name => "computer-icon-size", :hidden => true}

				.window-inside
					%nav.window-nav
						%h3.label-disk-small
							%span Ms-dos_5 (C:)
						.buttons
							%label.minimize{:for => "computer-minimize", :tabindex => 0}
							%label.maximize{:for => "computer-maximize", :tabindex => 0}
							%label.close{:for => "computer", :tabindex => 0}
					%menu.window-menu.underline
						%label.toggle-menu-label{:for => "computer-menu", "data-toggle" => true}
						%li
							%a.menu-item-file{:href => "#", "data-label" => true} File
							%menu.sub-menu.underline
								%li
									%a.label-nested
										%span
											%span> Ne
											%span.line> w
									%menu.sub-menu.underline
										%li
											%label.label-disabled Folder
										%li
											%label.label-disabled Shortcut
										%li
											%hr
										%li
											%label.label-disabled.no-line Text Document
								%li
									%hr
								%li
									%label.label-disabled
										%span
											%span> Create&nbsp;
											%span.line> Shortcut
								%li
									%label.label-disabled Delete
								%li
									%label.label-disabled
										%span
											%span> Rena
											%span.line> me
								%li
									%label.label-disabled Properties
								%li
									%hr
								%li
									%label{:for => "computer", :tabindex => 0} Close
						%li
							%a.menu-item-edit{:href => "#", "data-label" => true} Edit
							%menu.sub-menu.underline
								#{@editPartial}
								#{@editMenu}
						%li
							%a.menu-item-view{:href => "#", "data-label" => true} View
							%menu.sub-menu.underline
								%li
									%label.label-disabled Toolbar
								%li
									%label.label-check.label-status-bar{:for => "computer-menu-status-bar"}
										%span
											%span> Status&nbsp;
											%span.line> Bar
								%li
									%hr
								%li
									%label.label-check.label-icon-size.label-large-icons{:for => "computer-menu-large-icons"}
										%span
											%span> Lar
											%span.line> ge Icons
								%li
									%label.label-check.label-icon-size.label-small-icons{:for => "computer-menu-small-icons"}
										%span
											%span> S
											%span.line> mall Icons
								%li
									%label.label-check.label-icon-size.label-list-icons{:for => "computer-menu-list-icons"}
										%span.line List
								%li
									%label.label-disabled Details
								%li
									%hr
								#{@viewMenu}
						%li
							%a.menu-item-help{:href => "#", "data-label" => true} Help
							#{@helpMenu}
					.window-content
						.list-container.above-footer
							%menu.list
								- @diskFiles.each do |file|
									%li
										%label{:class => "label-#{file['label']}-small"} #{file['name']}
						%footer.window-footer
							%ul.number
								%li.show 11 object(s) (plus 14 hidden)
							%ul.space
								%li.show 954KB (Disk free space: 31.1MB)
								
			#window-notepad.window.window-default{"data-window" => true}
				%input.toggle-menu{:id => "notepad-menu", :type => "checkbox", :hidden => true, "data-menu" => true}

				.window-inside
					%nav.window-nav
						%h3.label-document-text-small
							%span Untitled - Notepad
						.buttons
							%label.minimize{:for => "notepad-minimize", :tabindex => 0}
							%label.maximize{:for => "notepad-maximize", :tabindex => 0}
							%label.close{:for => "notepad", :tabindex => 0}
					%menu.window-menu.underline
						%label.toggle-menu-label{:for => "notepad-menu", "data-toggle" => true}
						%li
							%a.menu-item-file{:href => "#", "data-label" => true} File
							%menu.sub-menu.underline
								%li
									%label.label-disabled New
								%li
									%label.label-disabled Open
								%li
									%label.label-disabled Save
								%li
									%label.label-disabled
										%span
											%span> Save&nbsp;
											%span.line> As
								%li
									%hr
								%li
									%label.label-disabled
										%span
											%span> Page Se
											%span.line> tup...
								%li
									%label.label-disabled Print
								%li
									%label{:for => "notepad"}
										%span
											%span> E
											%span.line> xit
						%li
							%a.menu-item-edit{:href => "#", "data-label" => true} Edit
							%menu.sub-menu.underline
								#{@editPartial}
								%li
									%label.label-disabled
										%span
											%span> De
											%span.line> lete
								%li
									%hr
								%li
									%label.label-disabled
										%span
											%span> Select&nbsp;
											%span.line> All
								%li
									%label.label-disabled
										%span
											%span> Time/
											%span.line> Date
								%li
									%hr
								%li
									%label.label-disabled Word Wrap
						%li
							%a.menu-item-search{:href => "#", "data-label" => true} Search
							%menu.sub-menu.underline
								%li
									%label.label-disabled Find
								%li
									%label.label-disabled
										%span
											%span> Find&nbsp;
											%span.line> Next
						%li
							%a.menu-item-help{:href => "#", "data-label" => true} Help
							%menu.sub-menu.underline
								%li
									%label.label-disabled Help Topics
								%li
									%hr
								%li
									%label.label-disabled About Notepad
					.window-content.textarea-container
						%textarea

			#window-explorer.window.window-default{"data-window" => true}
				%input.toggle-menu{:id => "explorer-menu", :type => "checkbox", :hidden => true, "data-menu" => true}

				%input#explorer-menu-status-bar.menu-status-bar{:type => "checkbox", :checked => true, :hidden => true}

				%input#explorer-menu-large-icons.menu-large-icons{:type => "radio", :name => "explorer-icon-size", :hidden => true}
				%input#explorer-menu-small-icons.menu-small-icons{:type => "radio", :name => "explorer-icon-size", :hidden => true}
				%input#explorer-menu-list-icons.menu-list-icons{:type => "radio", :name => "explorer-icon-size", :checked => true, :hidden => true}

				.window-inside
					%nav.window-nav
						%h3.label-folder-explorer-small
							%span
								%span.title-explorer-desktop Exploring - Desktop
								%span.title-explorer-computer Exploring - Computer
								%span.title-explorer-disk Exploring - Ms-dos_5 (C:)
								%span.title-explorer-dos Exploring - Dos
								%span.title-explorer-program-files Exploring - Program Files
								%span.title-explorer-windows Exploring - Windows
								%span.title-explorer-control-panel Exploring - Control Panel
								%span.title-explorer-printers Exploring - Printers
								%span.title-explorer-recycle-bin Exploring - Recycle Bin
						.buttons
							%label.minimize{:for => "explorer-minimize", :tabindex => 0}
							%label.maximize{:for => "explorer-maximize", :tabindex => 0}
							%label.close{:for => "explorer", :tabindex => 0}
					%menu.window-menu.underline
						%label.toggle-menu-label{:for => "explorer-menu", "data-toggle" => true}
						%li
							%a.menu-item-file{:href => "#", "data-label" => true} File
							%menu.sub-menu.underline
								%li
									%a.label-nested
										%span
											%span> Ne
											%span.line> w
									%menu.sub-menu.underline
										%li
											%label.label-disabled Folder
										%li
											%label.label-disabled Shortcut
										%li
											%hr
										%li
											%label.label-disabled.no-line Text Document
								%li
									%hr
								%li
									%label.label-disabled
										%span
											%span> Create&nbsp;
											%span.line> Shortcut
								%li
									%label.label-disabled Delete
								%li
									%label.label-disabled
										%span
											%span> Rena
											%span.line> me
								%li
									%label.label-disabled Properties
								%li
									%hr
								%li
									%label{:for => "explorer", :tabindex => 0} Close
						%li
							%a.menu-item-edit{:href => "#", "data-label" => true} Edit
							%menu.sub-menu.underline
								#{@editPartial}
								#{@editMenu}
						%li
							%a.menu-item-view{:href => "#", "data-label" => true} View
							%menu.sub-menu.underline
								%li
									%label.label-disabled Toolbar
								%li
									%label.label-check.label-status-bar{:for => "explorer-menu-status-bar"}
										%span
											%span> Status&nbsp;
											%span.line> Bar
								%li
									%hr
								%li
									%label.label-check.label-icon-size.label-large-icons{:for => "explorer-menu-large-icons"}
										%span
											%span> Lar
											%span.line> ge Icons
								%li
									%label.label-check.label-icon-size.label-small-icons{:for => "explorer-menu-small-icons"}
										%span
											%span> S
											%span.line> mall Icons
								%li
									%label.label-check.label-icon-size.label-list-icons{:for => "explorer-menu-list-icons"}
										%span.line List
								%li
									%label.label-disabled Details
								%li
									%hr
								#{@viewMenu}
						%li
							%a.menu-item-tools{:href => "#", "data-label" => true} Tools
							%menu.sub-menu.underline
								%li
									%a.label-nested Find
									%menu.sub-menu.underline
										%li
											%label.label-disabled Files or Folders
								%li
									%hr
								%li
									%label.label-disabled Go to...
						%li
							%a.menu-item-help{:href => "#", "data-label" => true} Help
							#{@helpMenu}
					.window-content
						.folders.above-footer
							%h4 All Folders
							.list-container
								%menu.list
									%li
										%label.label-desktop-small{:tabindex => 0, :for => "explorer-desktop"}
											%span Desktop
										%menu
											%li
												%label.label-toggle.toggle-computer{:for => "toggle-computer"}
												%label.label-computer-small{:tabindex => 0, :for => "explorer-computer"}
													%span My Computer
												%menu
													%li
														%label.label-toggle.toggle-error-a{:for => "error-diskette-a"}
														%label.label-diskette-small{:tabindex => 0, :for => "error-diskette-a"}
															%span 5¼ Floppy (A:)
													%li
														%label.label-toggle.toggle-error-b{:for => "error-diskette-b"}
														%label.label-diskette-small{:tabindex => 0, :for => "error-diskette-b"}
															%span 5¼ Floppy (B:)
													%li
														%label.label-toggle.toggle-disk{:for => "toggle-disk"}
														%label.label-disk-small{:tabindex => 0, :for => "explorer-disk"}
															%span Ms-dos_5 (C:)
														%menu
															%li
																%label.label-folder-small{:tabindex => 0, :for => "explorer-dos"}
																	%span Dos
															%li
																%label.label-toggle.toggle-program-files{:for => "toggle-program-files"}
																%label.label-folder-small{:tabindex => 0, :for => "explorer-program-files"}
																	%span Program Files
																%menu
																	- @programFiles.each do |file|
																		%li
																			%label.label-folder-small.long #{file}
															%li
																%label.label-toggle.toggle-windows{:for => "toggle-windows"}
																%label.label-folder-small{:tabindex => 0, :for => "explorer-windows"}
																	%span Windows
																%menu
																	- @windowsFolders.each do |folder|
																		%li
																			%label.label-folder-small #{folder}
													%li
														%label.label-control-panel-small{:tabindex => 0, :for => "explorer-control-panel"}
															%span Control Panel
													%li
														%label.label-folder-printers-small{:tabindex => 0, :for => "explorer-printers"}
															%span Printers
												%li
													%label.label-recycle-bin-small{:tabindex => 0, :for => "explorer-recycle-bin"}
														%span Recycle Bin
						.folders-content.above-footer
							.content.content-explorer-desktop
								%h5 Contents of Desktop
								.list-container
									%menu.list
										%li
											%label.label-computer-small{:tabindex => 0, :for => "explorer-computer"}
												%span My Computer
										%li
											%label.label-inbox-small
												%span Inbox
										%li
											%label.label-recycle-bin-small
												%span Recycle Bin
							.content.content-explorer-computer
								%h5 Contents of My Computer
								.list-container
									%menu.list
										%li
											%label.label-diskette-small{:tabindex => 0, :for => "error-diskette-a"}
												%span 5¼ Floppy (A:)
										%li
											%label.label-diskette-small{:tabindex => 0, :for => "error-diskette-b"}
												%span 5¼ Floppy (B:)
										%li
											%label.label-disk-small{:tabindex => 0, :for => "explorer-disk"}
												%span Ms-dos_5 (C:)
										%li
											%label.label-control-panel-small{:tabindex => 0, :for => "explorer-control-panel"}
												%span Control Panel
										%li
											%label.label-folder-printers-small{:tabindex => 0, :for => "explorer-printers"}
												%span Printers
							.content.content-explorer-disk
								%h5 Contents of Ms-dos_5 (C:)
								.list-container
									%menu.list
										- @diskFiles.each do |file|
											- if file['for']
												%li
													%label{:tabindex => 0, :for => "#{file['for']}", :class => "label-#{file['label']}-small"}
														%span #{file['name']}
											- else
												%li
													%label{:class => "label-#{file['label']}-small"} #{file['name']}
							.content.content-explorer-dos
								%h5 Contents of Dos
								.list-container
									%menu.list
										- @dosFiles.each do |file|
											%li
												%label{:class => "label-#{file['label']}-small"} #{file["name"]}
							.content.content-explorer-program-files
								%h5 Contents of Program Files
								.list-container
									%menu.list
										- @programFiles.each do |file|
											%li
												%label.label-folder-small.long #{file}
							.content.content-explorer-windows
								%h5 Contents of Windows
								.list-container
									%menu.list
										- @windowsFolders.each do |folder|
											%li
												%label.label-folder-small #{folder}
										- @windowsFiles.each do |file|
											%li
												%label{:class => "label-#{file['label']}-small"} #{file["name"]}
							.content.content-explorer-control-panel
								%h5 Contents of Control Panel
								.list-container
									%menu.list
										- @controlPanelItems.each do |item|
											- if item['for']
												%li
													%label{:class => "label-#{item['label']}-small", :tabindex => 0, :for => "#{item['for']}"}
														%span #{item["name"]}
											- else
												%li
													%label{:class => "label-#{item['label']}-small"} #{item["name"]}
							.content.content-explorer-printers
								%h5 Contents of Printers
								.list-container
									%menu.list
										%li
											%label.label-document-printer-small Add Printer
							.content.content-explorer-recycle-bin
								%h5 Contents of Recycle Bin
								.list-container
									%menu.list
						%footer.window-footer
							%ul.number
								%li.explorer-number-desktop 3 object(s)
								%li.explorer-number-computer 0 object(s)
								%li.explorer-number-disk 11 object(s) (plus 14 hidden)
								%li.explorer-number-dos 27 object(s) (plus 57 hidden)
								%li.explorer-number-program-files 2 object(s)
								%li.explorer-number-windows 33 object(s) (plus 77 hidden)
								%li.explorer-number-control-panel 15 object(s)
								%li.explorer-number-printers 1 object(s)
								%li.explorer-number-recycle-bin 0 object(s)
							%ul.space
								%li.explorer-space-disk 954KB (Disk free space: 31.1MB)
								%li.explorer-space-dos 2.09MB (Disk free space: 31.1MB)
								%li.explorer-space-program-files 0 bytes (Disk free space: 31.1MB)
								%li.explorer-space-windows 8.09MB (Disk free space: 31.1MB)
								%li.explorer-space-recycle-bin 0 bytes

	#start-menu-outline.start-menu-outline
	%nav#start-menu.start-menu
		%label.label-start{:for => "start", :tabindex => 0} Start
		.menu-container
			%menu.menu.main-menu.underline
				%li
					%a.label-folder-programs.label-nested
						%span Programs
					%menu.menu.sub-menu
						%li
							%a.label-folder-programs-small.label-nested
								%span Accessories
							%menu.menu.sub-menu
								%li
									%label.label-notepad-small{:for => "notepad"}
										%span Notepad
						%li
							%a.label-folder-programs-small.label-nested
								%span Start Up
							%menu.menu.sub-menu
								%li
									%a.label-empty
										%span (Empty)
						%li
							%label.label-folder-explorer-small{:for => "explorer"}
								%span Windows Explorer
				%li
					%a.label-folder-documents.label-nested
						%span Documents
					%menu.menu.sub-menu
						%li
							%a.label-empty
								%span (Empty)
				%li
					%a.label-settings.label-nested
						%span Settings
					%menu.menu.sub-menu.underline
						%li
							%label.label-control-panel-small{:for => "control-panel"}
								%span Control Panel
						%li
							%label.label-folder-printers-small{:for => "printers"}
								%span Printers
						%li
							%label.label-taskbar{:for => "taskbar"}
								%span Taskbar...
				%li
					%a.label-find.label-nested
						%span Find
					%menu.menu.sub-menu.underline
						%li
							%label.label-find-small.label-disabled
								%span Files or Folders
				%li
					%label.label-help
						%span Help
				%li
					%label.label-run
						%span Run...
				%li
					%label.label-shut-down{:for => "error-blue-screen"}
						%span
							%span> Sh
							%span.line> u
							%span> t Down
		%menu.tabs
			%li.tab.tab-printers{"data-tab" => true}
				%span.activate
				%label.label-folder-printers-small{:for => "printers-minimize"}
					%span Printers
			%li.tab.tab-control-panel{"data-tab" => true}
				%span.activate
				%label.label-control-panel-small{:for => "control-panel-minimize"}
					%span Control Panel
			%li.tab.tab-computer{"data-tab" => true}
				%span.activate
				%label.label-disk-small{:for => "computer-minimize"}
					%span Ms-dos_5 (C:)
			%li.tab.tab-notepad{"data-tab" => true}
				%span.activate
				%label.label-document-text-small{:for => "notepad-minimize"}
					%span Untitled - Notepad
			%li.tab.tab-explorer{"data-tab" => true}
				%span.activate
				%label.label-folder-explorer-small{:for => "explorer-minimize"}
					%span Exploring - Ms-dos_5 (C:)
		.time
			%time.clock 12:00 AM

	#alerts
		#alert-blue-screen
			.content
				%h3
					%span Windows
				%p An error has occured. To continue:
				%p Press Enter to return to Windows, or
				%p Press CTRL to restart your computer. If you do this, you will lose any unsaved information in all open applications.
				%p Error: GABRIELLEWEE1
				%p
					Press any key to continue
					%span.blink _
		#alert-diskette-a.alert{"data-window" => true}
			.alert-inside
				.alert-nav
					%h3
						%span Exploring - 5¼ Floppy (A:)
					.buttons
						%label.close{:for => "error-diskette-a"}
				.alert-content
					%p A:\ is not accessible.
					%p The device is not ready.
				%footer.alert-footer
					%button.button.underline{:tabindex => 0, "data-retry" => true}
						%span Retry
					%label.button{:for => "error-diskette-a", :tabindex => 0}
						%span Cancel

		#alert-diskette-b.alert{"data-window" => true}
			.alert-inside
				.alert-nav
					%h3
						%span Exploring - 5¼ Floppy (B:)
					.buttons
						%label.close{:for => "error-diskette-b"}
				.alert-content
					%p B:\ is not accessible.
					%p The device is not ready.
				%footer.alert-footer
					%button.button.underline{:tabindex => 0, "data-retry" => true}
						%span Retry
					%label.button{:for => "error-diskette-b", :tabindex => 0}
						%span Cancel
              
            
!

CSS

              
                // custom colors
$iron: #263238; $blush: #F5C8BF; $rose: #D19487; $mauve: #B2738E; $slate: #577783; $mint: #8BB29A; $oak: #D1AE87; $grey: #C5C1C6;
$g1: lighten($grey, 10%); $g2: lighten($grey, 2%); $g3: darken($grey, 15%); $hi: $blush; $wh: #fcfcfc; $bl: $iron; $bg: #fbe6e2;

// url
$url: "https://assets.codepen.io/345377/";

// arrows
$up: '';
$dn: '';
$lt: '';
$rt: '';
$re: '';
$x: '';
$y: '';
$o: '';
$q: '';

// mixins
@mixin ch($c: $g2, $s: 1px, $b: $wh) {
	background-color: $b;
	background-image: linear-gradient(45deg, $c 25%, transparent 25%, transparent 75%, $c 75%, $c), 
		linear-gradient(45deg, $c 25%, transparent 25%, transparent 75%, $c 75%, $c);
	background-size: $s*2 $s*2;
	background-position: 0 0, $s $s;
}
@mixin bt($w, $d: default, $c: true) {
	@include sh($w, $d);
	@if $c == true {
		display: flex;
		align-items: center;
		justify-content: center;
		padding-bottom: $w*.5;
	} @else {
		padding: $w*2;
	}
	z-index: 4;
	background: $g2;
}
@mixin sh($w, $d: default) {
	@if $d == default {
		box-shadow: inset #{-$w*.5} #{-$w*.5} 0 0 $bl, inset #{$w*.5} #{$w*.5} 0 0 $wh, inset #{-$w} #{-$w} 0 0 $g3, inset $w $w 0 0 $g1;
	} @else if $d == window {
		box-shadow: inset #{-$w*.5} #{-$w*.5} 0 0 $bl, inset #{$w*.5} #{$w*.5} 0 0 $g1, inset #{-$w} #{-$w} 0 0 $g3, inset $w $w 0 0 $wh;
	} @else if $d == button {
		box-shadow: inset #{-$w*.5} #{-$w*.5} 0 0 $bl, inset #{$w*.5} #{$w*.5} 0 0 $wh, inset #{-$w} #{-$w} 0 0 $g3, inset $w $w 0 0 $g2;
		padding-bottom: $w*.5;
		padding-right: $w*.5;
	} @else if $d == button-reverse {
		box-shadow: inset #{-$w*.5} #{-$w*.5} 0 0 $wh, inset #{$w*.5} #{$w*.5} 0 0 $bl, inset #{-$w} #{-$w} 0 0 $g2, inset $w $w 0 0 $g3;
		padding-bottom: $w*.5;
		padding-right: $w*.5;
	} @else if $d == button-strong {
		box-shadow: inset #{-$w} #{-$w} 0 0 $bl, inset #{$w*.5} #{$w*.5} 0 0 $bl, inset #{-$w*1.5} #{-$w*1.5} 0 0 $g3, inset $w $w 0 0 $wh;
		padding-bottom: $w*.5;
	} @else if $d == button-strong-pressed {
		box-shadow: inset #{-$w*.5} #{-$w*.5} 0 0 $bl, inset #{$w*.5} #{$w*.5} 0 0 $bl, inset #{-$w} #{-$w} 0 0 $g3, inset $w $w 0 0 $g3;
		padding-bottom: $w*.5;
	} @else if $d == inside {
		box-shadow: inset #{-$w*.5} #{-$w*.5} 0 0 $wh, inset #{$w*.5} #{$w*.5} 0 0 $g3, inset #{-$w} #{-$w} 0 0 $g2, inset $w $w 0 0 $bl;
		padding: $w;
	} @else if $d == inset {
		box-shadow: inset #{-$w*.5} #{-$w*.5} 0 0 $wh, inset #{$w*.5} #{$w*.5} 0 0 $g3;
	} @else if $d == hide {
		box-shadow: inset #{-$w*.5} 0 0 0 $bl, inset #{$w*.5} #{$w*.5} 0 0 $wh, inset #{-$w} 0 0 0 $g3, inset $w $w 0 0 $g1;
	} @else if $d == fieldset {
		box-shadow: inset #{-$w*.5} #{-$w*.5} 0 0 $wh, inset #{$w*.5} #{$w*.5} 0 0 $g3, inset #{-$w} #{-$w} 0 0 $g3, inset $w $w 0 0 $wh;
	}
}
@mixin nb {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
@mixin fl {
	&:first-letter {
		text-decoration: underline;
	}
}
@mixin li {
	display: flex;
	flex-direction: column;
	align-items: center;
	position: relative;
	width: 116px;
	&:before, &:after {
		width: 48px;
		height: 48px;
	}
	&:before {
		margin-bottom: 6px;
	}
	&:after {
		left: 36px;
	}
	span {
		padding: 1px;
		border: 1.5px solid transparent;
	}
}
@mixin ta {
	@include bt(3px, button-reverse);
	@include ch($wh, 1.5px, transparent);
	justify-content: flex-start;
}

// fonts
@font-face {
	font-family: "MS Sans Serif";
	src: url("#{$url}ms-sans-serif.woff2") format("woff2");
	font-weight: normal;
	font-display: swap;
}
@font-face {
	font-family: "MS Sans Serif";
	src: url("#{$url}ms-sans-serif-bold.woff2") format("woff2");
	font-weight: bold;
	font-display: swap;
}

// base styles
*, *:before, *:after {
	cursor: default;
	box-sizing: border-box;
	image-rendering: pixelated;
	font-family: "MS Sans Serif", Tahoma, Helvetica, Arial, sans-serif;
	font-size: 16px;
	text-decoration-thickness: 1.5px;
	text-underline-offset: 1px;
	// cursor: default;
	// cursor: url("#{$url}cursor.png") 0 0, pointer;
	// cursor: url("#{$url}cursor.svg") 0 0, pointer;
	// cursor: -webkit-image-set(url("#{$url}cursor.png") 1x, url("https://assets.codepen.io/345377/cursor@2x.png") 2x) 0 0, pointer;
}
*:not(textarea, input) {
	user-select: none;
	-webkit-tap-highlight-color: rgba(0,0,0,0);
}
*:focus { outline: none; }
::selection { background: none; }
body, html { height: 100%; }
body {
	margin: 0;
	background-color: $bg;
	color: $bl;
	line-height: 1;
	overflow: hidden;
}
textarea {
	display: block;
	border: 0;
	padding: 3px;
	width: 100%;
	height: 100%;
	resize: none;
	overflow: scroll;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.4;
	&::selection {
		background-color: $slate;
		-webkit-tap-highlight-color: $slate;
		color: white;
	}
}
.textarea-container {
	@include sh(3px, inside);
}
[hidden] {
	appearance: none;
	visibility: hidden;
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 0;
}

// menu and label styles
menu, ul:not(.information ul), ol {
	margin: 0;
	padding: 0;
	list-style: none;
}
.underline {
	> li {
		> a, > label {
			&:not(.no-line) {
				&, > span, .line {
					@include fl;
				}
				> span span:not(.line) {
					&:first-letter {
						text-decoration: none;
					}
				}
				.line {
					display: inline-block;
				}
			}
		}
	}
}
label, a {
	&:before, &:after {
		content: "";
		background-position: center center;
		background-size: contain;
	}
}
label[tabindex] {
	span {
		padding: 1px 2px;
		span {
			padding: 0;
		}
	}
}
[class*="label"]:not(.folders label):not(.label-nested) {
	&:after {
		@include ch($mauve, 1.5px, transparent);
		display: block;
		opacity: 0;
		position: absolute;
		top: 0;
		mask-position: center;
		mask-size: cover;
	}
	&[tabindex] {
		&:active, &:focus {
			&:after {
				opacity: 1;
			}
		}
	}
}
.label-nested {
	&:after {
		position: absolute;
		right: 6px;
		width: 16px;
		height: 16px;
		background-image: url($rt);
		background-size: 16px 16px;
	}
	&:hover:after {
		filter: invert(1) brightness(200%);
	}
}
li:hover > .label-nested {
	&:after {
		filter: invert(1) brightness(200%);
	}
}

// icons
$icons: folder-programs, folder-documents, settings, find, help, run, shut-down, notepad, folder-explorer, document-text, control-panel, folder-printers, desktop, computer, disk, diskette, folder, recycle-bin, inbox, program, program-config, document-windows, hardware, add-programs, date-time, document-misc, document-config, document-font, grpconv, folder-fonts-link, computer-display, modems, keyboard, internet, joystick, mouse, multimedia, network, passwords, battery, regional, folder-printers-link, computer-sounds, computer-mouse, document-printer, printer, volume, wordpad;
@each $icon in $icons {
	.label-#{$icon} {
		&:before {
			background-image: url("#{$url}#{$icon}.png");
			background-repeat: no-repeat;
		}
		&:not(.folders label):not(.label-nested) {
			&:after {
				mask-image: url("#{$url}#{$icon}.png");
			}
		}
	}
	.label-#{$icon}-small {
		&:before {
			background-image: url("#{$url}#{$icon}-small.png");
			background-repeat: no-repeat;
		}
		&:not(.folders label):not(.label-nested) {
			&:after {
				mask-image: url("#{$url}#{$icon}-small.png");
			}
		}
	}
}
$large-icons: taskbar, customize-start-menu, recycle-bin-folder;
@each $icon in $large-icons {
	.label-#{$icon}:before {
		background-image: url("#{$url}#{$icon}.png");
		background-repeat: no-repeat;
	}
}

// buttons
.button {
	@include bt(3px, button);
	appearance: none;
	display: flex;
	align-items: center;
	border: 0;
	padding-left: 6px;
	padding-right: 6px;
	width: 120px;
	height: 36px;
	background: none;
	text-align: center;
	&.underline {
		span {
			@include fl;
		}
	}
	+ .button {
		margin-left: 10px;
	}
	> span {
		display: block;
		width: 100%;
		line-height: 22px;
		border: 1px dotted transparent;
		padding: 0 !important;
		@media (min-width: 500px) {
			border-width: 1.5px;
		}
	}
	&[disabled] {
		color: $g3;
		pointer-events: none;
	}
	&:not([disabled]) {
		&:focus {
			@include bt(3px, button-strong);
		}
		&:active {
			@include bt(3px, button-strong-pressed);
		}
		&:focus, &:active {
			span {
				border-color: $bl;
				color: $bl;
				background: none;
			}
		}
	}
}

// desktop
#desktop {
	position: absolute;
	top: 0;
	left: 0;
	width: 100vw;
	height: calc(100vh - 44px);
}
#icons {
	position: relative;
	z-index: 1;
	padding-top: 3px;
	height: 100%;
}
.desktop-icon {
	@include li;
	&:not(:first-child) {
		margin-top: 40px;
	}
	&[tabindex] {
		&:active, &:focus {
			span {
				background: $mauve;
				color: white;
				border: 1px dotted $oak;
				@media (min-width: 500px) {
					border-width: 1.5px;
				}
			}
		}
	}
}

// windows and alerts
#windows, #alerts {
	display: grid;
	place-items: center;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: calc(100% + 44px);
	padding-bottom: 44px;
}
.window, .alert {
	@include bt(3px, window, false);
	opacity: 0;
	visibility: hidden;
	position: absolute;
	z-index: -1;
	background: $g2;
	&-inside {
		max-width: calc(100vw - 36px);
		max-height: calc(100vh - 44px - 12px);
		min-width: 300px;
		min-height: 200px;
		overflow: hidden;
		resize: both;
		&::-webkit-resizer {
			display: none;
		}
	}
}
.window-nav {
	background-color: $g3;
}
.alert-nav {
	background-color: $slate;
}
.window-nav, .alert-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 28px;
	padding: 0 3px;
	color: white;
	&:before, &:after {
		content: unset;
	}
	h3 {
		display: flex;
		align-items: center;
		justify-content: flex-start;
		width: calc(100% - 69px);
		margin: 0;
		line-height: 28px;
		&[class*="label"]:before {
			content: "";
			display: block;
			width: 24px;
			height: 24px;
			margin-right: 6px;
			background-size: contain;
		}
		&[class*="label"] span:only-child {
			@include nb;
			width: calc(100% - 24px - 6px);
		}
		&:not([class*="label"]) {
			padding: 0 3px;
		}
	}
	.buttons {
		display: flex;
		label {
			@include bt(3px, button);
			position: relative;
			width: 22px;
			height: 20px;
			background: $g2;
			&[disabled] {
				pointer-events: none;
				&:after {
					opacity: 0.4;
				}
			}
			&:last-child {
				margin-left: 3px;
			}
			&.minimize {
				&:after {
					display: block;
					position: absolute;
					bottom: 4.5px;
					left: 5px;
					width: 10px;
					height: 3px;
					background: $bl;
				}
			}
			&.maximize {
				&:before, &:after {
					content: "";
					display: block;
					position: absolute;
					width: 12px;
					height: 12px;
					border: 1.5px solid $bl;
					border-top-width: 3px;
					background-color: $g2;
				}
				&:before {
					visibility: hidden;
				}
			}
			&.close {
				&:after {
					content: "";
					background-image: url($x);
					width: 12px;
					height: 10px;
				}
			}
			&.question {
				&:after {
					content: "";
					background-image: url($q);
					width: 9px;
					height: 14px;
				}
			}
			&:not([disabled]):active {
				@include sh(3px, button-reverse);
			}
		}
	}
}
.window-menu {
	display: flex;
	position: relative;
	line-height: 25px;
	padding: 1.5px 0;
	li {
		position: relative;
	}
	> li {
		&:has(> .sub-menu:hover) > a {
			background-color: $slate;
			color: white;
		}
		> a {
			display: block;
			padding: 0 10px;
			text-decoration: none;
			color: $iron;
			&:before, &:after {
				content: unset;
			}
			&:hover {
				background-color: $slate;
				color: white;
				+ menu {
					visibility: visible;
					opacity: 1;
					z-index: 3;
				}
			}
		}
	}
	.sub-menu {
		@include bt(3px, window, false);
		background: $g2;
		position: absolute;
		width: 190px;
		z-index: -1;
		visibility: hidden;
		opacity: 0;
		&:hover {
			visibility: visible;
			opacity: 1;
			z-index: 3;
		}
		.sub-menu {
			top: -6px;
			left: calc(100% - 6px);
		}
		li {
			&:hover {
				> label, > a {
					background-color: $slate;
					color: white;
				}
			}
			label:not(.label-check) {
				display: block;
				&:before, &:after {
					content: unset;
				}
			}
			> a {
				display: flex;
				align-items: center;
				align-content: center;
			}
			> a, > label {
				padding-left: 32px;
				line-height: 28px;
				&:hover {
					background-color: $slate;
				}
				&:not(.label-disabled):hover {
					color: white;
				}
				&.label-disabled {
					color: $g3;
				}
			}
			a:hover ~ .sub-menu {
				visibility: visible;
				opacity: 1;
				z-index: 4;
			}
			.label-check {
				display: flex;
				padding-left: 0;
				&:before {
					visibility: hidden;
					content: "";
					display: block;
					background-repeat: no-repeat;
					background-position: center;
					width: 32px;
					height: 28px;
				}
				&:hover:before {
					filter: invert(1) brightness(200%);
				}
			}
		}
		hr {
			margin: 4px 0;
			border: 0;
			height: 3px;
			width: 100%;
			background: linear-gradient(to bottom, $g3 0%, $g3 50%, $wh 50%);
		}
	}
	.label-status-bar:before {
		background-image: url($y);
		background-size: 10px 10px;
	}
	.label-icon-size:before {
		background-image: url($o);
		background-size: 8px 8px;
	}
}
.toggle-menu-label {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
}
.toggle-menu:not(:checked) ~ .window-inside {
	.window-menu > li > a:hover {
		background-color: unset;
		color: $iron;
		+ .sub-menu {
			visibility: hidden;
			opacity: 0;
			z-index: -1;
		}
	}
}
.toggle-menu:checked ~ .window-inside .toggle-menu-label {
	z-index: -1;
}
.window-footer {
	.window-content & {
		display: none;
		width: 100%;
		height: 26px;
		margin-top: 3px;
		ul {
			@include sh(3px, inset);
			position: relative;
			height: 26px;
			line-height: 26px;
			li {
				@include nb;
				width: 100%;
				position: absolute;
				padding: 0 4px;
				&:not(.show) {
					visibility: hidden;
				}
			}
		}
		.number {
			width: 30%;
			&:only-child {
				width: 100%;
			}
		}
		.space {
			margin-left: 3px;
			width: calc(70% - 3px);
		}
	}
}
.window-default {
	.window-inside {
		width: 750px;
		height: 470px;
	}
}
.window-content {
	height: calc(100% - 56px);
	> .list-container {
		margin-top: 0;
	}
}
.list-container {
	@include sh(3px, inside);
	background: white;
	height: calc(100% - 28px - 2px);
	margin-top: 2px;
}
.list {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	align-content: flex-start;
	height: 100%;
	overflow: auto;
	li {
		position: relative;
	}
	label:not(.label-toggle) {
		display: flex;
		align-items: center;
		position: relative;
		padding-bottom: 3px;
		white-space: nowrap;
		&:not(.folders label) {
			&:after {
				width: 24px;
				height: 24px;
				z-index: 2;
			}
		}
		&:before {
			display: block;
			position: relative;
			z-index: 2;
			width: 24px;
			height: 24px;
			margin-right: 6px;
		}
		&:active, &:focus {
			span {
				background: $mauve;
				color: white;
				border: 1px dotted $oak;
				@media (min-width: 500px) {
					border-width: 1.5px;
				}
			}
		}
	}
	.label-toggle {
		display: block;
		position: absolute;
		top: 6px;
		left: -22px;
		width: 12.5px;
		height: 12.5px;
		box-shadow: inset -1.5px -1.5px 0 0 $g3, inset 1.5px 1.5px 0 0 $g3;
		background-color: white;
		&:before, &:after {
			display: block;
			position: absolute;
			background-color: $bl;
		}
		&:before {
			left: 3px;
			top: 5.5px;
			width: 6.5px;
			height: 1.5px;
		}
		&:after {
			left: 5.5px;
			top: 3px;
			width: 1.5px;
			height: 6.5px;
		}
		~ menu {
			display: none;
		}
	}
	menu {
		position: relative;
		padding-left: 26px;
		&:before {
			content: "";
			display: block;
			position: absolute;
			top: -3px;
			left: 9px;
			height: calc(100% - 12px);
			border-left: 1px dotted $g3;
			@media (min-width: 500px) {
				height: calc(100% - 11px);
				border-left-width: 1.5px;
			}
		}
		li {
			position: relative;
		}
	}
}
.above-footer {
	height: 100%;
}

#alerts {
	z-index: -1;
}
@keyframes blink {
	from { opacity: 1 } to { opacity: 0 }
}
#alert-blue-screen {
	opacity: 0;
	visibility: hidden;
	z-index: -1;
	display: grid;
	place-items: center;
	width: 100%;
	height: 100%;
	background-color: #00a;
	color: white;
	.content {
		max-width: 610px;
		padding: 20px;
	}
	h3, p {
		font-weight: bold;
		font-size: 18px;
		line-height: 1.4;
	}
	h3, p:last-child {
		text-align: center;
	}
	h3 span {
		display: inline-block;
		padding: 2px 3px;
		background-color: #aaa;
		color: #00a;
	}
	.blink {
		display: inline-block;
		animation: blink 1s cubic-bezier(1,0,0,1) infinite forwards;
	}
}
.alert-inside {
	min-width: unset;
	min-height: unset;
	width: 320px;
	height: 180px;
	resize: none;
}
.alert-content {
	padding: 0 24px;
	height: calc(100% - 28px - 52px);
	p {
		padding: 16px 0 0;
		margin: 0;
	}
}
.alert-footer {
	display: flex;
	padding: 0 24px 16px;
}

#window-welcome {
	.window-inside {
		height: 60vh;
		@media screen and (min-width: 568px) and (max-height: 450px), screen and (min-width: 768px) {
			width: 500px;
			height: 260px;
		}
		@media only screen and (min-width: 1000px) {
			width: 700px;
			height: 400px;
		}
	}
	.window-content {
		padding: 20px;
		height: calc(100% - 3px - 40px - 36px);
	}
	.window-footer {
		display: flex;
		justify-content: flex-end;
		padding-right: 19px;
		.button {
			@include bt(3px, button-strong);
			&:active {
				@include bt(3px, button-strong-pressed);
			}
		}
	}
	.information-container {
		@include sh(3px, inset);
		width: 100%;
		height: 100%;
		background: $wh;
		padding: 1.5px;
	}
	.information {
		overflow-y: scroll;
		width: 100%;
		height: 100%;
		padding: 20px;
		line-height: 1.4;
		h3, p, ul {
			margin: 1em 0 0;
		}
		h3:first-child {
			margin-top: 0;
		}
		ul {
			padding-left: 10px;
			list-style-type: "–";
			li {
				padding-left: 0.5em;
				&:not(:first-child) {
					margin-top: 0.25em;
				}
			}
		}
	}
}

#window-taskbar {
	left: 3px;
	bottom: 48px;
	> .window-inside {
		resize: none;
		width: 510px;
		height: 600px;
		> .window-content {
			padding: 12px 9px 10px;
			height: calc(100% - 28px - 3px - 36px - 9px);
		}
	}
	.window-footer {
		display: flex;
		justify-content: flex-end;
		width: 100%;
		padding: 0 9px;
	}
	.tab-container {
		height: 100%;
	}
	.tab-group {
		display: flex;
	}
	.tab {
		display: block;
		position: relative;
		z-index: 0;
		margin-top: 3px;
		line-height: 32px;
		padding: 0 12px;
		background-color: $g2;
		&:first-child {
			transform: translateX(3px);
		}
		&:not(:first-child) {
			margin-left: -3px;
			transform: translateX(-3px);
		}
		&:before, &:after, span:before, span:after {
			content: "";
			display: block;
			position: absolute;
		}
		&:before {
			width: calc(100% - 6px);
			height: 100%;
			top: 0;
			left: 3px;
			border-top: 1.5px solid $wh;
		}
		&:after {
			width: 100%;
			height: calc(100% - 3px);
			bottom: 0;
			left: 0;
			border-left: 1.5px solid $wh;
			border-right: 1.5px solid $bl;
			box-shadow: inset -1.5px 0 0 0 $g3;
		}
		span {
			&:before, &:after {
				top: 1.5px;
				width: 1.5px;
				height: 1.5px;
			}
			&:before {
				left: 1.5px;
				background-color: $wh;
			}
			&:after {
				right: 1.5px;
				background-color: $bl;;
			}
		}
	}
	$taskbar-tabs: taskbar-options, start-menu-programs;
	@each $tab in $taskbar-tabs {
		##{$tab}:checked ~ .window-inside {
			.tab-#{$tab} {
				z-index: 12;
				margin-top: 0;
				transform: none;
			}
			.tabpanel.#{$tab} {
				z-index: 12;
			}
		}
	}
	.tabpanel-group {
		position: relative;
		z-index: 0;
		margin-top: -1.5px;
		height: calc(100% - 32px + 1.5px);
	}
	.tabpanel {
		@include sh(3px, button);
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: flex-start;
		position: absolute;
		overflow: hidden;
		width: 100%;
		height: 100%;
		background-color: $g2;
	}

	.taskbar-options {
		padding: 32px;
	}
	.preview-container {
		@include sh(3px, inset);
		display: grid;
		place-items: center;
		width: 100%;
		height: 200px;
		background: $bg;
	}
	.preview {
		position: relative;
		overflow: hidden;
		width: calc(100% - 3px);
		height: calc(100% - 3px);
		* {
			pointer-events: none;
		}
		.window {
			opacity: 1;
			visibility: visible;
			z-index: 2;
			bottom: 22px;
			left: calc(100% - 96px);
		}
		.window-inside {
			width: 300px;
			height: 200px;
		}
		.window-content {
			height: 100%;
		}
		.list-container {
			height: 100%;
		}
		.list {
			display: block;
			label {
				display: flex;
				flex-direction: column;
				align-items: center;
				position: relative;
				width: 116px;
				height: 98px;
				white-space: unset;
				text-align: center;
				line-height: 1.3;
				&:before {
					margin-bottom: 6px;
					margin-right: 0;
					width: 48px;
					height: 48px;
				}
			}
		}
		.start-menu, .start-menu-outline {
			bottom: 1px;
			left: 4px;
			width: calc(100% - 8px);
		}
		.start-menu-outline {
			visibility: hidden;
			position: absolute;
			height: 44px;
			border: 1.5px dotted $mint;
			border-bottom: 0;
			z-index: 10;
		}
		.start-menu {
			@include sh(3px);
			padding: 0 2px 0 1px;
			justify-content: space-between;
			.label-start {
				@include sh(3px, button-reverse);
			}
			.menu-container {
				visibility: visible;
				z-index: 2;
				left: 0;
				bottom: 44px;
			}
			.time {
				display: flex;
				align-items: center;
				width: auto;
				padding: 0 10px;
				&:before {
					content: "";
					width: 24px;
					height: 24px;
					margin-right: 8px;
					background-size: contain;
				}
			}
		}
	}
	.options {
		width: 100%;
		label {
			display: flex;
			align-items: center;
			margin-top: 32px;
			position: relative;
			&:before, &:after {
				display: block;
				width: 20px;
				height: 20px;
			}
			&:before {
				@include sh(3px, inside);
				margin-right: 8px;
				background-color: white;
			}
			&:after {
				position: absolute;
				left: 0;
				visibility: hidden;
				background-repeat: no-repeat;
				background-position: center;
				background-image: url($y);
				background-size: 10px 10px;
			}
			> span {
				border: 1.5px dotted transparent;
				line-height: 1;
				height: 20px;
			}
			&:focus {
				> span {
					border: 1.5px dotted;
				}
			}
		}
	}

	.start-menu-programs {
		padding: 0 20px 20px;
		form {
			display: block;
			width: 100%;
		}
		fieldset {
			@include sh(3px, fieldset);
			display: block;
			width: 100%;
			margin-top: 20px;
			border: 0;
			padding: 32px 32px 20px;
		}
		legend {
			background-color: $g2;
			margin-left: -22px;
			transform: translateY(2px);
			padding: 0 5px;
		}
		p {
			display: flex;
			align-items: flex-start;
			width: calc(100% - 20px);
			margin: 0;
			line-height: 1.3;
			&:before {
				content: "";
				display: block;
				min-width: 48px;
				width: 48px;
				height: 48px;
				background-size: contain;
				margin-right: 24px;
			}
		}
		.menu-options {
			display: flex;
			justify-content: flex-end;
			li {
				&:not(:first-child) {
					margin-left: 10px;
				}
			}
		}
		.customize-start-menu {
			.menu-options {
				margin-top: 48px;
			}
		}
		.documents-menu {
			.menu-options {
				margin-top: 20px;
			}
		}
	}
}
$options: always-on-top, auto-hide, show-small-icons, show-clock;
@each $option in $options {
	#option-#{$option}:checked ~ .window-inside {
		label[for="option-#{$option}"] {
			&:after {
				visibility: visible;
			}
		}
	}
}
#option-always-on-top:not(:checked) ~ .window-inside .preview .window {
	z-index: 11;
}
#global-option-always-on-top:not(:checked) ~ main {
	#start-menu {
		z-index: unset;
		.menu-container {
			z-index: 1000000;
		}
	}
}
#start:checked ~ #global-option-always-on-top:not(:checked) ~ main {
	#start-menu {
		z-index: 1000000;
		.menu-container {
			z-index: unset;
		}
	}
}
#option-auto-hide:checked ~ .window-inside .preview {
	.start-menu-outline {
		visibility: visible;
	}
	.start-menu {
		@include sh(3px, hide);
		height: 10px;
		> * {
			visibility: hidden;
		}
	}
}
#global-option-auto-hide:checked ~ main:not(#start:checked ~ main) {
	.start-menu {
		transform: translateY(100%);
		&:hover {
			transform: none;
		}
	}
	#start-menu-outline {
		visibility: visible;
		&:hover {
			+ .start-menu {
				transform: none;
			}
		}
	}
}
#option-show-small-icons:checked ~ .window-inside .preview, #global-option-show-small-icons:checked ~ main #start-menu {
	$small-icons: folder-programs, folder-documents, settings, find, help, run, shut-down;
	@each $icon in $small-icons {
		.label-#{$icon} {
			&:before {
				background-image: url("#{$url}#{$icon}-small.png");
			}
		}
	}
	.menu-container:before {
		display: none;
	}
	.main-menu {
		> li {
			&:last-child {
				padding-top: 8px;
			}
			> a, > label {
				height: 34px;
				width: 175px;
				&:before {
					width: 24px;
					height: 24px;
					margin-right: 8px;
				}
			}
		}
	}
}
#option-show-clock:not(:checked) ~ .window-inside .preview {
	.time:before {
		margin-right: 0;
	}
	time {
		display: none;
	}
}
#global-option-show-clock:not(:checked) ~ main #start-menu .time {
	display: none;
}

#window-printers {
	.window-inside {
		width: 480px;
		height: 390px;
	}
}
#window-control-panel {
	.window-inside {
		width: 520px;
		height: 480px;
	}
}
#window-explorer {
	.window-nav {
		h3 > span {
			position: relative;
			height: 28px;
			span {
				visibility: hidden;
				top: 0;
				position: absolute;
			}
		}
	}
	.window-content {
		display: flex;
		flex-wrap: wrap;
		h4, h5 {
			@include nb;
			@include sh(3px, inset);
			margin: 0;
			padding: 0 6px;
			font-weight: normal;
			line-height: 28px;
		}
		.folders {
			width: 250px;
			.long {
				min-width: 180px;
			}
			label:not(.label-toggle) {
				&:after {
					display: block;
					position: absolute;
					z-index: 1;
					left: -17px;
					width: 17px;
					border-top: 1px dotted $g3;
					@media (min-width: 500px) {
						left: -14px;
						width: 14px;
						border-top-width: 1.5px;
					}
				}
			}
		}
		.folders-content {
			position: relative;
			margin-left: 4px;
			width: calc(100% - 254px);
		}
		.content {
			opacity: 0;
			visibility: hidden;
			position: absolute;
			z-index: -1;
			width: 100%;
			height: 100%;
			.list {
				li {
					min-width: 210px;
				}
			}
		}
	}
}

$windows: welcome, taskbar, printers, control-panel, computer, notepad, explorer;
@each $window in $windows {
	##{$window} {
		&:checked ~ main {
			#window-#{$window} {
				will-change: transform;
				opacity: 1;
				visibility: visible;
				z-index: 2;
			}
			.tab-#{$window} {
				display: flex;
			}
			.menu .label-#{$window} {
				pointer-events: none;
			}
		}
		&.active ~ ##{$window}-minimize:not(:checked) ~ main,
		&.active.no-tab ~ main {
			#window-#{$window} {
				z-index: 10;
				.window-nav {
					background-color: $slate;
				}
			}
			.window[data-window]:not(#window-#{$window}) {
				z-index: 2;
			}
			.tab-#{$window} label {
				@include ta;
			}
			.activate:not(.tab-#{$window} .activate) {
				z-index: 1;
			}
			.tab label:not(.tab-#{$window} label) {
				z-index: 0;
			}
		}
	}
	##{$window}-minimize {
		&:active ~ main #window-#{$window} .window-inside {
			.minimize {
				@include sh(3px, button-reverse);
			}
		}
		&:checked ~ main #window-#{$window} {
			transform: scale(0);
		}
	}
	##{$window}-maximize {
		&:active ~ main #window-#{$window} .window-inside {
			.maximize {
				@include sh(3px, button-reverse);
			}
		}
		&:checked ~ main #window-#{$window} {
			left: unset !important;
			top: 0 !important;
			.window-inside {
				max-width: calc(100vw - 12px);
				width: calc(100vw - 12px) !important;
				height: calc(100vh - 44px - 12px) !important;
				.maximize {
					&:before, &:after {
						width: 9px;
						height: 9px;
					}
					&:before {
						visibility: visible;
						top: 3px;
						right: 6px;
					}
					&:after {
						bottom: 4px;
						left: 4px;
					}
				}
			}
		}
	}
}

.menu-status-bar:checked ~ .window-inside {
	.label-check.label-status-bar:before {
		visibility: visible;
	}
	.window-footer {
		display: flex;
	}
	.above-footer {
		height: calc(100% - 26px - 3px);
	}
}
.menu-large-icons:checked ~ .window-inside {
	.label-check.label-large-icons:before {
		visibility: visible;
	}
	.window-content {
		.list:not(.folders .list) {
			display: grid !important;
			grid-template-columns: repeat(auto-fill, 120px);
			row-gap: 24px;
			padding: 9px 0;
			li {
				label {
					white-space: unset;
					text-align: center;
					line-height: 1.3;
					height: 98px;
					&:before {
						margin-bottom: 6px;
						margin-right: 0;
					}
					&:active, &:focus {
						span {
							background: $mauve;
							color: white;
							border: 1px dotted $oak;
							@media (min-width: 500px) {
								border-width: 1.5px;
							}
						}
					}
				}
			}
		}
		@each $icon in $icons {
			.label-#{$icon}-small:not(.folders label) {
				@include li;
				&:before {
					background-image: url("#{$url}#{$icon}.png");
				}
		}
	}
}
}
.menu-small-icons:checked ~ .window-inside {
	.label-check.label-small-icons:before {
		visibility: visible;
	}
	.window-content {
		.list:not(.folders .list) {
			flex-direction: row;
			label {
				width: 210px;
			}
		}
	}
}
.menu-list-icons:checked ~ .window-inside {
	.label-check.label-list-icons:before {
		visibility: visible;
	}
	.window-content {
		.list:not(.folders list) {
			flex-direction: column;
		}
	}
}

$alerts: blue-screen, diskette-a, diskette-b;
input[id*="error-"]:checked ~ main #alerts {
	z-index: 1000001;
}
@each $alert in $alerts {
	#error-#{$alert} {
		&:checked ~ main {
			#alert-#{$alert} {
				will-change: transform;
				opacity: 1;
				visibility: visible;
				z-index: 2;
			}
		}
	}
}

$toggles: computer, disk, program-files, windows;
@each $toggle in $toggles {
	#toggle-#{$toggle} {
		&:checked ~ main #window-explorer {
			.toggle-#{$toggle} {
				&:after {
					visibility: hidden;
				}
				~ menu {
					display: block;
				}
			}
		}
	}
}

$explorer-panels: desktop, computer, disk, dos, program-files, windows, control-panel, printers, recycle-bin;
@each $panel in $explorer-panels {
	#explorer-#{$panel} {
		&:checked ~ main #window-explorer {
			.title-explorer-#{$panel}, .content-explorer-#{$panel}, .explorer-number-#{$panel}, .explorer-space-#{$panel} {
				visibility: visible;
			}
			.label-folder-small[for="explorer-#{$panel}"]:before {
				background-image: url("#{$url}folder-open-small.png");
			}
			.content-explorer-#{$panel} {
				visibility: visible;
				opacity: 1;
				z-index: unset;
			}
		}
	}
}

// start menu
#start {
	&:focus, &:active, &:checked {
		~ main > .start-menu .label-start {
			outline: 1px dotted $bl;
			outline-offset: -6px;
			@media (min-width: 500px) {
				outline-width: 1.5px;
			}
		}
	}
	&:active, &:checked {
		~ main > .start-menu .label-start {
			@include sh(3px, button-reverse);
		}
	}
	&:checked {
		~ main > .start-menu .menu-container {
			visibility: visible;
			z-index: unset;
			.sub-menu:hover {
				visibility: visible;
				z-index: 2;
			}
			.main-menu {
				a:hover ~ .sub-menu {
					visibility: visible;
					opacity: 1;
					z-index: 2;
				}
			}
		}
	}
}
#start-menu-outline {
	visibility: hidden;
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 3px;
	background-color: $g3;
}
.start-menu {
	display: flex;
	align-items: center;
	position: absolute;
	z-index: 10;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 44px;
	background-color: $g2;
	box-shadow: inset 0 1.5px 0 0 $g2, inset 0 3px 0 0 $wh;
	padding-top: 3px;
	.menu-container, .sub-menu {
		@include bt(3px);
		position: absolute;
		padding: 4px;
	}
	.menu {
		li {
			position: relative;
			&:hover {
				> label, > a {
					background-color: $slate;
					color: white;
				}
			}
		}
		label, a {
			display: flex;
			align-items: center;
			align-content: center;
			width: 200px;
			padding-left: 8px;
			height: 32px;
			&:before {
				width: 24px;
				height: 24px;
				margin-right: 8px;
			}
			&:hover {
				background-color: $slate;
				color: white;
			}
			&.label-empty {
				justify-content: center;
				padding-left: 0;
				&:before, &:after {
					display: none;
				}
			}
			&.label-disabled, &.label-empty {
				&, &:hover {
					color: #85888c;
				}
			}
		}
	}
	.menu-container {
		visibility: hidden;
		display: flex;
		align-items: stretch;
		z-index: -1;
		bottom: 38px;
		left: 4px;
		&:before {
			content: "";
			display: block;
			background-color: desaturate(lighten($slate, 15%), 15%);
			width: 32px;
		}
		.sub-menu {
			visibility: hidden;
			z-index: -1;
			display: block;
			top: -4px;
			left: calc(100% - 4px);
			margin: 0;
		}
		.main-menu {
			> li {
				&:nth-last-child(2) {
					border-bottom: 1.5px solid $g3;
				}
				&:last-child {
					border-top: 1.5px solid $wh;
				}
				> label, > a {
					height: 50px;
					&:before {
						width: 48px;
						height: 48px;
						margin-right: 10px;
					}
				}
			}
		}
	}
	.label-start {
		font-weight: bold;
		margin-left: 4px;
		&:before {
			width: 24px;
			height: 21px;
			margin-right: 5px;
			background-image: url("#{$url}start.png");
			background-size: 24px 21px;
		}
	}
	.label-start, .tabs label {
		@include bt(3px, button);
		height: 34px;
		padding: 0 6px !important;
		background-color: $g2;
	}
	.tabs {
		display: flex;
		width: calc(100% - 79px - 100px - 6px);
		.tab {
			flex-basis: 200px;
			display: none;
			position: relative;
			overflow: hidden;
			margin-left: 4px;
		}
		.activate {
			position: absolute;
			top: 0;
			left: 0;
			width: 100%;
			height: 100%;
			z-index: 0;
		}
		label {
			position: relative;
			z-index: 1;
			width: 100%;
			justify-content: flex-start;
			span {
				@include nb;
			}
			&:before {
				width: 24px;
				min-width: 24px;
				height: 24px;
				margin-right: 3px;
			}
			&:active {
				@include ta;
			}
		}
	}
	.time {
		@include nb;
		@include sh(3px, inset);
		display: grid;
		place-items: center;
		height: 34px;
		width: 100px;
		margin: 0 3px;
	}
}
#start-menu {
	z-index: 1000000;
}

// scrollbar
// https://codepen.io/louh/pen/oZJQvm
$sc-wd: 24px;
::-webkit-scrollbar {
	width: $sc-wd;
	height: $sc-wd;
}
::-webkit-scrollbar-track {
	@include ch(lighten($g2, 15%));
}
::-webkit-scrollbar-thumb {
	@include sh(3px);
	width: $sc-wd;
	height: $sc-wd;
	background-color: $g2;
	z-index: 1;
}
::-webkit-scrollbar-corner {
	background-color: $g2;
}
::-webkit-resizer {
	width: $sc-wd;
	height: $sc-wd;
	background-color: $g2;
	background-color: transparent;
	background-image: url($re);
	background-position: bottom right;
	background-repeat: no-repeat;
	image-rendering: pixelated;
}
::-webkit-scrollbar-button {
	@include sh(3px);
	display: block;
	width: $sc-wd;
	height: $sc-wd;
	background-color: $g2;
	image-rendering: pixelated;
	background-size: $sc-wd*.75 $sc-wd*.75;
	background-repeat: no-repeat;
	background-position: center center;
	&:active {
		background-position: 2px 2px;
	}
	&:horizontal:decrement {
		background-image: url($lt);
	}
	&:horizontal:increment {
		background-image: url($rt);
	}
	&:vertical:decrement {
		background-image: url($up);
	}
	&:vertical:increment {
		background-image: url($dn);
	}
	&:horizontal:increment:start { display: none; }
	&:horizontal:decrement:end { display: none; }
	&:vertical:increment:start { display: none; }
	&:vertical:decrement:end { display: none; }
	&:active {
		border: 1.5px solid $g3;
		box-shadow: none;
	}
}
              
            
!

JS

              
                const start = document.querySelector("[data-start]");
const windows =  [... document.querySelectorAll("[data-window]")];
const triggers = [... document.querySelectorAll("[data-window-trigger]")];
const errors = [... document.querySelectorAll("[data-error-trigger]")];

start.addEventListener("click", e => {
	if(start.checked) {
		start.setAttribute("checked", "");
	} else {
		start.removeAttribute("checked");
	}
	triggers.forEach(trigger=>{
		trigger.classList.remove("active");
	});
});

const desktop = document.querySelector("#icons");
desktop.addEventListener("click", e => {
	triggers.forEach(trigger=>{
		trigger.classList.remove("active");
	});
	start.checked = false;
	start.removeAttribute("checked");
});

const taskbar = document.querySelector("#window-taskbar");
const close = taskbar.querySelector("[data-close]");
close.removeAttribute("disabled");
const applies = [... document.querySelectorAll("[data-apply]")];
const global = [... document.querySelectorAll("[data-global-option]")];
const options = [... document.querySelectorAll("[data-option]")];
const outline = document.querySelector("#start-menu-outline");
options.forEach(option => {
	option.addEventListener("click", e => {
		applies[1].removeAttribute("disabled")
	})
})
applies.forEach(apply => {
	apply.addEventListener("click", e => {
		options.forEach((option, index) => {
			if(option.checked) {
				global[index].checked = true;
				global[index].setAttribute("checked", "");
			} else {
				global[index].checked = false;
				global[index].removeAttribute("checked");
			}
		});
	});
});

const bars = [... document.querySelectorAll(".menu-status-bar")];
bars.forEach(bar=>{
	bar.addEventListener("click", e => {
		if(bar.checked) {
			bar.setAttribute("checked", "");
		} else {
			bar.removeAttribute("checked");
		}
	});
});

const welcome = document.querySelector("#welcome");
const welcomeInside = document.querySelector("#window-welcome .window-inside");
errors.forEach(error=>{
	let name = error.getAttribute("data-name");
	let alert = document.querySelector(`#alert-${name}`);
	let retry = alert.querySelector("[data-retry]");
	error.addEventListener("click", e => {
		if(error.checked) {
			error.setAttribute("checked", "");
			if(retry) retry.focus();
			if(name == "blue-screen") {
				document.addEventListener("keydown", e => {
					if (e.key === "Enter" && error.checked) {
						error.checked = false;
						error.removeAttribute("checked");
					} else if (e.key === "Control") {
						error.checked = false;
						error.removeAttribute("checked");
						start.checked = false;
						start.removeAttribute("checked");
						triggers.forEach(trigger=>{
							trigger.checked = false;
							trigger.classList.remove("active");
						});
						welcome.checked = true;
						welcome.setAttribute("checked", "");
						welcome.classList.add("active");
						welcomeInside.removeAttribute("style");
					} else {
						error.checked = false;
						error.removeAttribute("checked");
					}
				});
			}
		} else {
			error.removeAttribute("checked");
		}
	});
});

let order = 0;
let layer = 10;
triggers.forEach(trigger=>{
	let name = trigger.getAttribute("data-name");
	let window = document.querySelector(`#window-${name}`);
	let inside = window.querySelector(".window-inside");
	let tab = document.querySelector(`.tab-${name}`);
	let menu = window.querySelector("[data-menu]");
	let max = document.querySelector(`#${name}-maximize`);
	let drag;
	window.addEventListener("click", e => {
		start.checked = false;
		start.removeAttribute("checked");
		if(!trigger.classList.contains("active")) {
			triggers.forEach(trigger=>{
				trigger.classList.remove("active");
			});
			trigger.classList.add("active");
		}
	});
	trigger.addEventListener("click", e => {
		start.checked = false;
		start.removeAttribute("checked");
		if(trigger.checked) {
			trigger.setAttribute("checked", "");
			triggers.forEach(trigger=>{
				trigger.classList.remove("active");
			});
			trigger.classList.add("active");
			order = order + 1;
			if(tab) tab.style.order = order;
			layer = layer + 1;
			window.style.zIndex = layer;
			window.setAttribute("data-index", layer);
			drag = new Draggabilly(window, {
				handle: ".window-nav",
				containment: true
			});
			if(window == taskbar) close.focus();
		} else {
			trigger.classList.remove("active");
			trigger.removeAttribute("checked");
			inside.removeAttribute("style");
			window.removeAttribute("data-index");
			if(drag != undefined) drag.destroy();
			window.removeAttribute("style");
			if(menu) {
				menu.checked = false;
				menu.removeAttribute("checked");
			}
			if(max) max.checked = false;
		}
	});
});

const minimizers = [... document.querySelectorAll("[data-minimize]")];
minimizers.forEach((minimizer, index)=>{
	let name = minimizer.getAttribute("data-name");
	let trigger = document.querySelector(`#${name}`);
	let tab = document.querySelector(`.tab-${name} .activate`);
	let window = document.querySelector(`#window-${name}`);
	tab.addEventListener("click", e => {
		triggers.forEach(trigger=>{
			trigger.classList.remove("active");
		});
		trigger.classList.add("active");
		let layers = [... document.querySelectorAll("[data-index]")];
		if(layers.length > 1 && !minimizer.checked) {
			let values = [];
			layers.forEach(layer=>{
				values.push(layer.getAttribute("data-index"));
			});
			let highest = Math.max(...values) + 1;
			window.style.zIndex = highest;
			window.setAttribute("data-index", highest);
		}
	});
	minimizer.addEventListener("click", e => {
		if(minimizer.checked) {
			minimizer.setAttribute("checked", "");
			trigger.classList.remove("active");
		} else {
			minimizer.removeAttribute("checked");
			triggers.forEach(trigger=>{
				trigger.classList.remove("active");
			});
			trigger.classList.add("active");
		}
	});
});

windows.forEach(window=>{
	let menu = window.querySelector("[data-menu]");
	let toggle = window.querySelector("[data-toggle]");
	let labels =  [... window.querySelectorAll("[data-label]")];
	if(toggle) {
		toggle.addEventListener("pointerdown", e => {
			menu.checked = true;
			menu.setAttribute("checked", "");
		});
	}
	if(labels.length > 0) {
		labels.forEach(label => {
			label.addEventListener("click", e => {
				menu.checked = false;
				menu.removeAttribute("checked");
			});
		});
	}
});

const time = document.querySelector(".clock");
const updateTime = () => {
	let date = luxon.DateTime.fromJSDate(new Date()).toLocaleString(luxon.DateTime.TIME_SIMPLE);
	time.innerHTML = date;
}
updateTime();
setInterval(() => updateTime(), 1000);
              
            
!
999px

Console